home *** CD-ROM | disk | FTP | other *** search
Emacs Compiled Lisp | 1998-05-21 | 44.7 KB |
open in:
MacOS 8.1
|
Win98
|
DOS
view JSON data
|
view as text
This file was processed as: Emacs Compiled Lisp
(other/emacsCompiledLisp).
This format is not currently supported by dexvert.
Confidence | Program | Detection | Match Type | Support
|
---|
1%
| dexvert
| Emacs Compiled Lisp (other/emacsCompiledLisp)
| magic
| Unsupported |
100%
| file
| Emacs/XEmacs v20 byte-compiled Lisp data
| default
| |
99%
| file
| data
| default
| |
100%
| TrID
| Emacs/XEmacs byte-compiled Lisp (generic)
| default
|
|
hex view+--------+-------------------------+-------------------------+--------+--------+
|00000000| 3b 45 4c 43 14 00 00 00 | 0a 3b 3b 3b 20 63 6f 6d |;ELC....|.;;; com|
|00000010| 70 69 6c 65 64 20 62 79 | 20 6a 75 73 74 69 6e 62 |piled by| justinb|
|00000020| 40 65 62 6f 6e 79 2e 63 | 72 61 79 2e 63 6f 6d 20 |@ebony.c|ray.com |
|00000030| 6f 6e 20 54 68 75 20 4a | 61 6e 20 32 32 20 31 34 |on Thu J|an 22 14|
|00000040| 3a 34 34 3a 30 33 20 31 | 39 39 38 0a 3b 3b 3b 20 |:44:03 1|998.;;; |
|00000050| 66 72 6f 6d 20 66 69 6c | 65 20 2f 68 6f 6d 65 2f |from fil|e /home/|
|00000060| 61 73 70 65 6e 30 37 2f | 6a 75 73 74 69 6e 62 2f |aspen07/|justinb/|
|00000070| 72 6f 6f 74 73 2f 66 72 | 65 65 77 61 72 65 2f 78 |roots/fr|eeware/x|
|00000080| 65 6d 61 63 73 2f 78 65 | 6d 61 63 73 2d 32 30 2e |emacs/xe|macs-20.|
|00000090| 33 2f 6c 69 73 70 2f 75 | 74 69 6c 73 2f 61 64 76 |3/lisp/u|tils/adv|
|000000a0| 69 63 65 2e 65 6c 0a 3b | 3b 3b 20 65 6d 61 63 73 |ice.el.;|;; emacs|
|000000b0| 20 76 65 72 73 69 6f 6e | 20 32 30 2e 33 20 22 56 | version| 20.3 "V|
|000000c0| 61 74 69 63 61 6e 20 43 | 69 74 79 22 20 58 45 6d |atican C|ity" XEm|
|000000d0| 61 63 73 20 20 4c 75 63 | 69 64 2e 0a 3b 3b 3b 20 |acs Luc|id..;;; |
|000000e0| 62 79 74 65 63 6f 6d 70 | 20 76 65 72 73 69 6f 6e |bytecomp| version|
|000000f0| 20 32 2e 32 35 20 58 45 | 6d 61 63 73 3b 20 32 32 | 2.25 XE|macs; 22|
|00000100| 2d 4d 61 72 2d 39 36 2e | 0a 3b 3b 3b 20 6f 70 74 |-Mar-96.|.;;; opt|
|00000110| 69 6d 69 7a 61 74 69 6f | 6e 20 69 73 20 6f 6e 2e |imizatio|n is on.|
|00000120| 0a 3b 3b 3b 20 74 68 69 | 73 20 66 69 6c 65 20 75 |.;;; thi|s file u|
|00000130| 73 65 73 20 6f 70 63 6f | 64 65 73 20 77 68 69 63 |ses opco|des whic|
|00000140| 68 20 64 6f 20 6e 6f 74 | 20 65 78 69 73 74 20 69 |h do not| exist i|
|00000150| 6e 20 45 6d 61 63 73 20 | 31 39 2e 0a 0a 28 69 66 |n Emacs |19...(if|
|00000160| 20 28 61 6e 64 20 28 62 | 6f 75 6e 64 70 20 27 65 | (and (b|oundp 'e|
|00000170| 6d 61 63 73 2d 76 65 72 | 73 69 6f 6e 29 0a 09 20 |macs-ver|sion).. |
|00000180| 28 6f 72 20 28 61 6e 64 | 20 28 62 6f 75 6e 64 70 |(or (and| (boundp|
|00000190| 20 27 65 70 6f 63 68 3a | 3a 76 65 72 73 69 6f 6e | 'epoch:|:version|
|000001a0| 29 20 65 70 6f 63 68 3a | 3a 76 65 72 73 69 6f 6e |) epoch:|:version|
|000001b0| 29 0a 09 20 20 20 20 20 | 28 73 74 72 69 6e 67 2d |).. |(string-|
|000001c0| 6c 65 73 73 70 20 65 6d | 61 63 73 2d 76 65 72 73 |lessp em|acs-vers|
|000001d0| 69 6f 6e 20 22 32 30 22 | 29 29 29 0a 20 20 20 20 |ion "20"|))). |
|000001e0| 28 65 72 72 6f 72 20 22 | 60 61 64 76 69 63 65 2e |(error "|`advice.|
|000001f0| 65 6c 27 20 77 61 73 20 | 63 6f 6d 70 69 6c 65 64 |el' was |compiled|
|00000200| 20 66 6f 72 20 45 6d 61 | 63 73 20 32 30 22 29 29 | for Ema|cs 20"))|
|00000210| 0a 0a 28 6f 72 20 28 62 | 6f 75 6e 64 70 20 27 63 |..(or (b|oundp 'c|
|00000220| 75 72 72 65 6e 74 2d 6c | 6f 61 64 2d 6c 69 73 74 |urrent-l|oad-list|
|00000230| 29 20 28 73 65 74 71 20 | 63 75 72 72 65 6e 74 2d |) (setq |current-|
|00000240| 6c 6f 61 64 2d 6c 69 73 | 74 20 6e 69 6c 29 29 0a |load-lis|t nil)).|
|00000250| 0a 0a 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |..(byte-|code "..|
|00000260| 21 88 c2 c1 c3 5c 22 87 | 22 20 5b 70 72 6f 76 69 |!....\".|" [provi|
|00000270| 64 65 20 61 64 76 69 63 | 65 2d 70 72 65 6c 6f 61 |de advic|e-preloa|
|00000280| 64 20 72 65 71 75 69 72 | 65 20 22 61 64 76 69 63 |d requir|e "advic|
|00000290| 65 2e 65 6c 22 5d 20 33 | 29 0a 28 64 65 66 61 6c |e.el"] 3|).(defal|
|000002a0| 69 61 73 20 27 61 64 2d | 78 65 6d 61 63 73 2d 70 |ias 'ad-|xemacs-p|
|000002b0| 20 27 28 6d 61 63 72 6f | 20 2e 20 23 5b 6e 69 6c | '(macro| . #[nil|
|000002c0| 20 22 c0 c1 5c 6e 5c 22 | 87 22 20 5b 73 74 72 69 | "..\n\"|." [stri|
|000002d0| 6e 67 2d 6d 61 74 63 68 | 20 22 58 45 6d 61 63 73 |ng-match| "XEmacs|
|000002e0| 22 20 65 6d 61 63 73 2d | 76 65 72 73 69 6f 6e 5d |" emacs-|version]|
|000002f0| 20 33 5d 29 29 0a 28 62 | 79 74 65 2d 63 6f 64 65 | 3])).(b|yte-code|
|00000300| 20 22 c0 11 c1 5c 6e 42 | 12 c1 87 22 20 5b 22 32 | "...\nB|..." ["2|
|00000310| 2e 31 34 22 20 61 64 2d | 76 65 72 73 69 6f 6e 20 |.14" ad-|version |
|00000320| 63 75 72 72 65 6e 74 2d | 6c 6f 61 64 2d 6c 69 73 |current-|load-lis|
|00000330| 74 5d 20 32 29 0a 23 40 | 36 31 35 20 2a 44 65 66 |t] 2).#@|615 *Def|
|00000340| 69 6e 65 73 20 77 68 61 | 74 20 74 6f 20 64 6f 20 |ines wha|t to do |
|00000350| 77 69 74 68 20 72 65 64 | 65 66 69 6e 69 74 69 6f |with red|efinitio|
|00000360| 6e 73 20 64 75 72 69 6e | 67 20 41 64 76 69 63 65 |ns durin|g Advice|
|00000370| 20 64 65 2f 61 63 74 69 | 76 61 74 69 6f 6e 2e 0a | de/acti|vation..|
|00000380| 52 65 64 65 66 69 6e 69 | 74 69 6f 6e 20 6f 63 63 |Redefini|tion occ|
|00000390| 75 72 73 20 69 66 20 61 | 20 70 72 65 76 69 6f 75 |urs if a| previou|
|000003a0| 73 6c 79 20 61 63 74 69 | 76 61 74 65 64 20 66 75 |sly acti|vated fu|
|000003b0| 6e 63 74 69 6f 6e 20 74 | 68 61 74 20 61 6c 72 65 |nction t|hat alre|
|000003c0| 61 64 79 20 68 61 73 20 | 61 6e 0a 6f 72 69 67 69 |ady has |an.origi|
|000003d0| 6e 61 6c 20 64 65 66 69 | 6e 69 74 69 6f 6e 20 61 |nal defi|nition a|
|000003e0| 73 73 6f 63 69 61 74 65 | 64 20 77 69 74 68 20 69 |ssociate|d with i|
|000003f0| 74 20 67 65 74 73 20 72 | 65 64 65 66 69 6e 65 64 |t gets r|edefined|
|00000400| 20 61 6e 64 20 74 68 65 | 6e 20 64 65 2f 61 63 74 | and the|n de/act|
|00000410| 69 76 61 74 65 64 2e 0a | 49 6e 20 73 75 63 68 20 |ivated..|In such |
|00000420| 61 20 63 61 73 65 20 77 | 65 20 63 61 6e 20 65 69 |a case w|e can ei|
|00000430| 74 68 65 72 20 61 63 63 | 65 70 74 20 74 68 65 20 |ther acc|ept the |
|00000440| 63 75 72 72 65 6e 74 20 | 64 65 66 69 6e 69 74 69 |current |definiti|
|00000450| 6f 6e 20 61 73 20 74 68 | 65 20 6e 65 77 0a 6f 72 |on as th|e new.or|
|00000460| 69 67 69 6e 61 6c 20 64 | 65 66 69 6e 69 74 69 6f |iginal d|efinitio|
|00000470| 6e 2c 20 64 69 73 63 61 | 72 64 20 74 68 65 20 63 |n, disca|rd the c|
|00000480| 75 72 72 65 6e 74 20 64 | 65 66 69 6e 69 74 69 6f |urrent d|efinitio|
|00000490| 6e 20 61 6e 64 20 72 65 | 70 6c 61 63 65 20 69 74 |n and re|place it|
|000004a0| 20 77 69 74 68 20 74 68 | 65 0a 6f 6c 64 20 6f 72 | with th|e.old or|
|000004b0| 69 67 69 6e 61 6c 2c 20 | 6f 72 20 6b 65 65 70 20 |iginal, |or keep |
|000004c0| 69 74 20 61 6e 64 20 72 | 61 69 73 65 20 61 6e 20 |it and r|aise an |
|000004d0| 65 72 72 6f 72 2e 20 20 | 54 68 65 20 76 61 6c 75 |error. |The valu|
|000004e0| 65 73 20 60 61 63 63 65 | 70 74 27 2c 20 60 64 69 |es `acce|pt', `di|
|000004f0| 73 63 61 72 64 27 2c 0a | 60 65 72 72 6f 72 27 20 |scard',.|`error' |
|00000500| 6f 72 20 60 77 61 72 6e | 27 20 67 6f 76 65 72 6e |or `warn|' govern|
|00000510| 20 77 68 61 74 20 77 69 | 6c 6c 20 62 65 20 64 6f | what wi|ll be do|
|00000520| 6e 65 2e 20 20 60 77 61 | 72 6e 27 20 69 73 20 6a |ne. `wa|rn' is j|
|00000530| 75 73 74 20 6c 69 6b 65 | 20 60 61 63 63 65 70 74 |ust like| `accept|
|00000540| 27 20 62 75 74 0a 69 74 | 20 61 64 64 69 74 69 6f |' but.it| additio|
|00000550| 6e 61 6c 6c 79 20 70 72 | 69 6e 74 73 20 61 20 77 |nally pr|ints a w|
|00000560| 61 72 6e 69 6e 67 20 6d | 65 73 73 61 67 65 2e 20 |arning m|essage. |
|00000570| 20 41 6c 6c 20 6f 74 68 | 65 72 20 76 61 6c 75 65 | All oth|er value|
|00000580| 73 20 77 69 6c 6c 20 62 | 65 0a 69 6e 74 65 72 70 |s will b|e.interp|
|00000590| 72 65 74 65 64 20 61 73 | 20 60 65 72 72 6f 72 27 |reted as| `error'|
|000005a0| 2e 1f 0a 28 64 65 66 76 | 61 72 20 61 64 2d 72 65 |...(defv|ar ad-re|
|000005b0| 64 65 66 69 6e 69 74 69 | 6f 6e 2d 61 63 74 69 6f |definiti|on-actio|
|000005c0| 6e 20 27 77 61 72 6e 20 | 28 23 24 20 2e 20 2d 38 |n 'warn |(#$ . -8|
|000005d0| 32 38 29 29 0a 23 40 35 | 30 31 20 2a 44 65 66 69 |28)).#@5|01 *Defi|
|000005e0| 6e 65 73 20 77 68 65 74 | 68 65 72 20 74 6f 20 63 |nes whet|her to c|
|000005f0| 6f 6d 70 69 6c 65 20 61 | 64 76 69 73 65 64 20 64 |ompile a|dvised d|
|00000600| 65 66 69 6e 69 74 69 6f | 6e 73 20 64 75 72 69 6e |efinitio|ns durin|
|00000610| 67 20 61 63 74 69 76 61 | 74 69 6f 6e 2e 0a 41 20 |g activa|tion..A |
|00000620| 76 61 6c 75 65 20 6f 66 | 20 60 61 6c 77 61 79 73 |value of| `always|
|00000630| 27 20 77 69 6c 6c 20 72 | 65 73 75 6c 74 20 69 6e |' will r|esult in|
|00000640| 20 75 6e 63 6f 6e 64 69 | 74 69 6f 6e 61 6c 20 63 | uncondi|tional c|
|00000650| 6f 6d 70 69 6c 61 74 69 | 6f 6e 2c 20 60 6e 65 76 |ompilati|on, `nev|
|00000660| 65 72 27 20 77 69 6c 6c | 0a 61 6c 77 61 79 73 20 |er' will|.always |
|00000670| 61 76 6f 69 64 20 63 6f | 6d 70 69 6c 61 74 69 6f |avoid co|mpilatio|
|00000680| 6e 2c 20 60 6d 61 79 62 | 65 27 20 77 69 6c 6c 20 |n, `mayb|e' will |
|00000690| 63 6f 6d 70 69 6c 65 20 | 69 66 20 74 68 65 20 62 |compile |if the b|
|000006a0| 79 74 65 2d 63 6f 6d 70 | 69 6c 65 72 20 69 73 20 |yte-comp|iler is |
|000006b0| 61 6c 72 65 61 64 79 0a | 6c 6f 61 64 65 64 2c 20 |already.|loaded, |
|000006c0| 61 6e 64 20 60 6c 69 6b | 65 2d 6f 72 69 67 69 6e |and `lik|e-origin|
|000006d0| 61 6c 27 20 77 69 6c 6c | 20 63 6f 6d 70 69 6c 65 |al' will| compile|
|000006e0| 20 69 66 20 74 68 65 20 | 6f 72 69 67 69 6e 61 6c | if the |original|
|000006f0| 20 64 65 66 69 6e 69 74 | 69 6f 6e 20 6f 66 20 74 | definit|ion of t|
|00000700| 68 65 0a 61 64 76 69 73 | 65 64 20 66 75 6e 63 74 |he.advis|ed funct|
|00000710| 69 6f 6e 20 69 73 20 63 | 6f 6d 70 69 6c 65 64 20 |ion is c|ompiled |
|00000720| 6f 72 20 61 20 62 75 69 | 6c 74 2d 69 6e 20 66 75 |or a bui|lt-in fu|
|00000730| 6e 63 74 69 6f 6e 2e 20 | 45 76 65 72 79 20 6f 74 |nction. |Every ot|
|00000740| 68 65 72 20 76 61 6c 75 | 65 20 77 69 6c 6c 0a 62 |her valu|e will.b|
|00000750| 65 20 69 6e 74 65 72 70 | 72 65 74 65 64 20 61 73 |e interp|reted as|
|00000760| 20 60 6d 61 79 62 65 27 | 2e 20 54 68 69 73 20 76 | `maybe'|. This v|
|00000770| 61 72 69 61 62 6c 65 20 | 77 69 6c 6c 20 6f 6e 6c |ariable |will onl|
|00000780| 79 20 62 65 20 63 6f 6e | 73 69 64 65 72 65 64 20 |y be con|sidered |
|00000790| 69 66 20 74 68 65 20 0a | 43 4f 4d 50 49 4c 45 20 |if the .|COMPILE |
|000007a0| 61 72 67 75 6d 65 6e 74 | 20 6f 66 20 60 61 64 2d |argument| of `ad-|
|000007b0| 61 63 74 69 76 61 74 65 | 27 20 77 61 73 20 73 75 |activate|' was su|
|000007c0| 70 70 6c 69 65 64 20 61 | 73 20 6e 69 6c 2e 1f 0a |pplied a|s nil...|
|000007d0| 28 64 65 66 76 61 72 20 | 61 64 2d 64 65 66 61 75 |(defvar |ad-defau|
|000007e0| 6c 74 2d 63 6f 6d 70 69 | 6c 61 74 69 6f 6e 2d 61 |lt-compi|lation-a|
|000007f0| 63 74 69 6f 6e 20 27 6d | 61 79 62 65 20 28 23 24 |ction 'm|aybe (#$|
|00000800| 20 2e 20 2d 31 34 39 39 | 29 29 0a 28 64 65 66 61 | . -1499|)).(defa|
|00000810| 6c 69 61 73 20 27 61 64 | 2d 73 75 62 73 74 69 74 |lias 'ad|-substit|
|00000820| 75 74 65 2d 74 72 65 65 | 20 23 5b 28 73 55 62 54 |ute-tree| #[(sUbT|
|00000830| 72 45 65 2d 54 65 53 74 | 20 66 55 6e 43 74 49 6f |rEe-TeSt| fUnCtIo|
|00000840| 4e 20 74 52 65 45 29 20 | 22 08 3a ab a3 09 08 40 |N tReE) |".:....@|
|00000850| 21 ab 86 5c 6e 08 40 21 | aa 8f 08 40 3a ab 88 c3 |!..\n.@!|...@:...|
|00000860| 09 5c 6e 08 40 23 aa 82 | 08 40 c3 09 5c 6e 08 41 |.\n.@#..|.@..\n.A|
|00000870| 23 42 87 09 08 21 ab 84 | 5c 6e 08 21 87 08 87 22 |#B...!..|\n.!..."|
|00000880| 20 5b 74 52 65 45 20 73 | 55 62 54 72 45 65 2d 54 | [tReE s|UbTrEe-T|
|00000890| 65 53 74 20 66 55 6e 43 | 74 49 6f 4e 20 61 64 2d |eSt fUnC|tIoN ad-|
|000008a0| 73 75 62 73 74 69 74 75 | 74 65 2d 74 72 65 65 5d |substitu|te-tree]|
|000008b0| 20 35 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 5]).(de|falias '|
|000008c0| 61 64 2d 63 6f 70 79 2d | 74 72 65 65 20 23 5b 28 |ad-copy-|tree #[(|
|000008d0| 74 72 65 65 29 20 22 08 | 3a ab 8a c1 08 40 21 c1 |tree) ".|:....@!.|
|000008e0| 08 41 21 42 87 08 87 22 | 20 5b 74 72 65 65 20 61 |.A!B..."| [tree a|
|000008f0| 64 2d 63 6f 70 79 2d 74 | 72 65 65 5d 20 33 5d 29 |d-copy-t|ree] 3])|
|00000900| 0a 23 40 34 30 39 20 41 | 20 43 6f 6d 6d 6f 6e 2d |.#@409 A| Common-|
|00000910| 4c 69 73 70 2d 73 74 79 | 6c 65 20 64 6f 6c 69 73 |Lisp-sty|le dolis|
|00000920| 74 20 69 74 65 72 61 74 | 6f 72 20 77 69 74 68 20 |t iterat|or with |
|00000930| 74 68 65 20 66 6f 6c 6c | 6f 77 69 6e 67 20 73 79 |the foll|owing sy|
|00000940| 6e 74 61 78 3a 0a 0a 20 | 20 20 20 28 61 64 2d 64 |ntax:.. | (ad-d|
|00000950| 6f 6c 69 73 74 20 28 56 | 41 52 20 49 4e 49 54 2d |olist (V|AR INIT-|
|00000960| 46 4f 52 4d 20 5b 52 45 | 53 55 4c 54 2d 46 4f 52 |FORM [RE|SULT-FOR|
|00000970| 4d 5d 29 0a 20 20 20 20 | 20 20 20 42 4f 44 59 2d |M]). | BODY-|
|00000980| 46 4f 52 4d 2e 2e 2e 29 | 0a 0a 77 68 69 63 68 20 |FORM...)|..which |
|00000990| 77 69 6c 6c 20 69 74 65 | 72 61 74 65 20 6f 76 65 |will ite|rate ove|
|000009a0| 72 20 74 68 65 20 6c 69 | 73 74 20 79 69 65 6c 64 |r the li|st yield|
|000009b0| 65 64 20 62 79 20 49 4e | 49 54 2d 46 4f 52 4d 20 |ed by IN|IT-FORM |
|000009c0| 62 69 6e 64 69 6e 67 20 | 56 41 52 20 74 6f 20 74 |binding |VAR to t|
|000009d0| 68 65 0a 63 75 72 72 65 | 6e 74 20 68 65 61 64 20 |he.curre|nt head |
|000009e0| 61 74 20 65 76 65 72 79 | 20 69 74 65 72 61 74 69 |at every| iterati|
|000009f0| 6f 6e 2e 20 20 49 66 20 | 52 45 53 55 4c 54 2d 46 |on. If |RESULT-F|
|00000a00| 4f 52 4d 20 69 73 20 73 | 75 70 70 6c 69 65 64 20 |ORM is s|upplied |
|00000a10| 69 74 73 20 76 61 6c 75 | 65 20 77 69 6c 6c 0a 62 |its valu|e will.b|
|00000a20| 65 20 72 65 74 75 72 6e | 65 64 20 61 74 20 74 68 |e return|ed at th|
|00000a30| 65 20 65 6e 64 20 6f 66 | 20 74 68 65 20 69 74 65 |e end of| the ite|
|00000a40| 72 61 74 69 6f 6e 2c 20 | 6e 69 6c 20 6f 74 68 65 |ration, |nil othe|
|00000a50| 72 77 69 73 65 2e 20 20 | 54 68 65 20 69 74 65 72 |rwise. |The iter|
|00000a60| 61 74 69 6f 6e 20 63 61 | 6e 20 62 65 0a 65 78 69 |ation ca|n be.exi|
|00000a70| 74 65 64 20 70 72 65 6d | 61 74 75 72 65 6c 79 20 |ted prem|aturely |
|00000a80| 77 69 74 68 20 60 28 61 | 64 2d 64 6f 2d 72 65 74 |with `(a|d-do-ret|
|00000a90| 75 72 6e 20 5b 56 41 4c | 55 45 5d 29 27 2e 1f 0a |urn [VAL|UE])'...|
|00000aa0| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 64 6f |(defalia|s 'ad-do|
|00000ab0| 6c 69 73 74 20 27 28 6d | 61 63 72 6f 20 2e 20 23 |list '(m|acro . #|
|00000ac0| 5b 28 76 61 72 66 6f 72 | 6d 20 26 72 65 73 74 20 |[(varfor|m &rest |
|00000ad0| 62 6f 64 79 29 20 22 c0 | c1 5c 6e 41 40 44 5c 6e |body) ".|.\nA@D\n|
|00000ae0| 40 44 c3 c1 c4 5c 6e 40 | c5 42 42 c6 0e 07 c8 5c |@D...\n@|.BB....\|
|00000af0| 22 42 42 42 5c 6e 41 41 | 40 46 1e 09 ca cb 8d ab |"BBB\nAA|@F......|
|00000b00| 87 cc cd 0e 09 45 aa 82 | 0e 09 29 87 22 20 5b 6c |.....E..|..)." [l|
|00000b10| 65 74 20 61 64 2d 64 4f | 2d 76 41 72 20 76 61 72 |et ad-dO|-vAr var|
|00000b20| 66 6f 72 6d 20 77 68 69 | 6c 65 20 73 65 74 71 20 |form whi|le setq |
|00000b30| 28 28 63 61 72 20 61 64 | 2d 64 4f 2d 76 41 72 29 |((car ad|-dO-vAr)|
|00000b40| 29 20 61 70 70 65 6e 64 | 20 62 6f 64 79 20 28 28 |) append| body ((|
|00000b50| 73 65 74 71 20 61 64 2d | 64 4f 2d 76 41 72 20 28 |setq ad-|dO-vAr (|
|00000b60| 63 64 72 20 61 64 2d 64 | 4f 2d 76 41 72 29 29 29 |cdr ad-d|O-vAr)))|
|00000b70| 20 65 78 70 61 6e 73 69 | 6f 6e 20 63 6f 6e 74 61 | expansi|on conta|
|00000b80| 69 6e 73 2d 72 65 74 75 | 72 6e 20 28 62 79 74 65 |ins-retu|rn (byte|
|00000b90| 2d 63 6f 64 65 20 22 c0 | c1 c2 0b 23 88 c4 87 22 |-code ".|...#..."|
|00000ba0| 20 5b 61 64 2d 73 75 62 | 73 74 69 74 75 74 65 2d | [ad-sub|stitute-|
|00000bb0| 74 72 65 65 20 23 5b 28 | 73 75 62 74 72 65 65 29 |tree #[(|subtree)|
|00000bc0| 20 22 08 a2 c1 61 ae 8a | 08 a2 c2 61 ad 84 c3 c4 | "...a..|...a....|
|00000bd0| c5 5c 22 87 22 20 5b 73 | 75 62 74 72 65 65 20 61 |.\"." [s|ubtree a|
|00000be0| 64 2d 64 6f 6c 69 73 74 | 20 61 64 2d 64 6f 2d 72 |d-dolist| ad-do-r|
|00000bf0| 65 74 75 72 6e 20 74 68 | 72 6f 77 20 63 6f 6e 74 |eturn th|row cont|
|00000c00| 61 69 6e 73 2d 72 65 74 | 75 72 6e 20 74 5d 20 33 |ains-ret|urn t] 3|
|00000c10| 5d 20 69 64 65 6e 74 69 | 74 79 20 62 6f 64 79 20 |] identi|ty body |
|00000c20| 6e 69 6c 5d 20 34 29 20 | 63 61 74 63 68 20 27 61 |nil] 4) |catch 'a|
|00000c30| 64 2d 64 4f 2d 65 58 69 | 54 5d 20 38 20 28 23 24 |d-dO-eXi|T] 8 (#$|
|00000c40| 20 2e 20 32 33 31 31 29 | 5d 29 29 0a 28 64 65 66 | . 2311)|])).(def|
|00000c50| 61 6c 69 61 73 20 27 61 | 64 2d 64 6f 2d 72 65 74 |alias 'a|d-do-ret|
|00000c60| 75 72 6e 20 27 28 6d 61 | 63 72 6f 20 2e 20 23 5b |urn '(ma|cro . #[|
|00000c70| 28 76 61 6c 75 65 29 20 | 22 c0 c1 5c 6e 45 87 22 |(value) |"..\nE."|
|00000c80| 20 5b 74 68 72 6f 77 20 | 27 61 64 2d 64 4f 2d 65 | [throw |'ad-dO-e|
|00000c90| 58 69 54 20 76 61 6c 75 | 65 5d 20 33 5d 29 29 0a |XiT valu|e] 3])).|
|00000ca0| 28 62 79 74 65 2d 63 6f | 64 65 20 22 c0 c1 4e ac |(byte-co|de "..N.|
|00000cb0| 86 c2 c0 c1 c3 23 88 c0 | 87 22 20 5b 61 64 2d 64 |.....#..|." [ad-d|
|00000cc0| 6f 6c 69 73 74 20 6c 69 | 73 70 2d 69 6e 64 65 6e |olist li|sp-inden|
|00000cd0| 74 2d 68 6f 6f 6b 20 70 | 75 74 20 31 5d 20 34 29 |t-hook p|ut 1] 4)|
|00000ce0| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 73 |.(defali|as 'ad-s|
|00000cf0| 61 76 65 2d 72 65 61 6c | 2d 64 65 66 69 6e 69 74 |ave-real|-definit|
|00000d00| 69 6f 6e 20 27 28 6d 61 | 63 72 6f 20 2e 20 23 5b |ion '(ma|cro . #[|
|00000d10| 28 66 75 6e 63 74 69 6f | 6e 29 20 22 c0 c1 c2 0b |(functio|n) "....|
|00000d20| 5c 22 21 1c c5 c6 c7 5c | 22 88 c8 c9 ca cb 0c 44 |\"!....\|"......D|
|00000d30| 44 44 cc cd cb 0c 44 ce | cb 0b 44 44 45 cf 0b c6 |DD....D.|..DDE...|
|00000d40| 4e ad 8c d0 cb 0c 44 d1 | cb 0b c6 4e 44 46 43 0b |N.....D.|...NDFC.|
|00000d50| d2 4e ad 8c d0 cb 0c 44 | d3 cb 0b d2 4e 44 46 43 |.N.....D|....NDFC|
|00000d60| 5c 22 42 42 45 29 87 22 | 20 5b 69 6e 74 65 72 6e |\"BBE)."| [intern|
|00000d70| 20 66 6f 72 6d 61 74 20 | 22 61 64 2d 72 65 61 6c | format |"ad-real|
|00000d80| 2d 25 73 22 20 66 75 6e | 63 74 69 6f 6e 20 73 61 |-%s" fun|ction sa|
|00000d90| 76 65 64 2d 66 75 6e 63 | 74 69 6f 6e 20 72 65 71 |ved-func|tion req|
|00000da0| 75 69 72 65 20 62 79 74 | 65 2d 63 6f 6d 70 69 6c |uire byt|e-compil|
|00000db0| 65 20 22 62 79 74 65 63 | 6f 6d 70 22 20 69 66 20 |e "bytec|omp" if |
|00000dc0| 6e 6f 74 20 66 62 6f 75 | 6e 64 70 20 71 75 6f 74 |not fbou|ndp quot|
|00000dd0| 65 20 70 72 6f 67 6e 20 | 66 73 65 74 20 73 79 6d |e progn |fset sym|
|00000de0| 62 6f 6c 2d 66 75 6e 63 | 74 69 6f 6e 20 61 70 70 |bol-func|tion app|
|00000df0| 65 6e 64 20 70 75 74 20 | 27 62 79 74 65 2d 63 6f |end put |'byte-co|
|00000e00| 6d 70 69 6c 65 20 62 79 | 74 65 2d 6f 70 63 6f 64 |mpile by|te-opcod|
|00000e10| 65 20 27 62 79 74 65 2d | 6f 70 63 6f 64 65 5d 20 |e 'byte-|opcode] |
|00000e20| 31 32 5d 29 29 0a 28 64 | 65 66 61 6c 69 61 73 20 |12])).(d|efalias |
|00000e30| 27 61 64 2d 73 61 76 65 | 2d 72 65 61 6c 2d 64 65 |'ad-save|-real-de|
|00000e40| 66 69 6e 69 74 69 6f 6e | 73 20 23 5b 6e 69 6c 20 |finition|s #[nil |
|00000e50| 22 c0 c1 21 ac 91 c1 c2 | 4b 4d 88 c3 c1 c4 c5 23 |"..!....|KM.....#|
|00000e60| 88 c3 c1 c6 c7 23 88 c0 | c8 21 3f ad 84 c8 c9 4b |.....#..|.!?....K|
|00000e70| 4d 87 22 20 5b 66 62 6f | 75 6e 64 70 20 61 64 2d |M." [fbo|undp ad-|
|00000e80| 72 65 61 6c 2d 66 73 65 | 74 20 66 73 65 74 20 70 |real-fse|t fset p|
|00000e90| 75 74 20 62 79 74 65 2d | 63 6f 6d 70 69 6c 65 20 |ut byte-|compile |
|00000ea0| 62 79 74 65 2d 63 6f 6d | 70 69 6c 65 2d 66 73 65 |byte-com|pile-fse|
|00000eb0| 74 20 62 79 74 65 2d 6f | 70 63 6f 64 65 20 62 79 |t byte-o|pcode by|
|00000ec0| 74 65 2d 66 73 65 74 20 | 61 64 2d 72 65 61 6c 2d |te-fset |ad-real-|
|00000ed0| 64 6f 63 75 6d 65 6e 74 | 61 74 69 6f 6e 20 64 6f |document|ation do|
|00000ee0| 63 75 6d 65 6e 74 61 74 | 69 6f 6e 5d 20 34 5d 29 |cumentat|ion] 4])|
|00000ef0| 0a 28 62 79 74 65 2d 63 | 6f 64 65 20 22 c0 20 88 |.(byte-c|ode ". .|
|00000f00| c1 c2 21 ac 82 c3 12 c2 | 0c 42 14 c3 87 22 20 5b |..!.....|.B..." [|
|00000f10| 61 64 2d 73 61 76 65 2d | 72 65 61 6c 2d 64 65 66 |ad-save-|real-def|
|00000f20| 69 6e 69 74 69 6f 6e 73 | 20 62 6f 75 6e 64 70 20 |initions| boundp |
|00000f30| 61 64 2d 61 64 76 69 73 | 65 64 2d 66 75 6e 63 74 |ad-advis|ed-funct|
|00000f40| 69 6f 6e 73 20 6e 69 6c | 20 63 75 72 72 65 6e 74 |ions nil| current|
|00000f50| 2d 6c 6f 61 64 2d 6c 69 | 73 74 5d 20 32 29 0a 28 |-load-li|st] 2).(|
|00000f60| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 70 75 73 |defalias| 'ad-pus|
|00000f70| 68 6e 65 77 2d 61 64 76 | 69 73 65 64 2d 66 75 6e |hnew-adv|ised-fun|
|00000f80| 63 74 69 6f 6e 20 27 28 | 6d 61 63 72 6f 20 2e 20 |ction '(|macro . |
|00000f90| 23 5b 28 66 75 6e 63 74 | 69 6f 6e 29 20 22 c0 c1 |#[(funct|ion) "..|
|00000fa0| c2 c3 0c 44 c5 42 42 44 | c6 c7 c8 c9 c3 0c 44 44 |...D.BBD|......DD|
|00000fb0| ca 42 42 45 45 87 22 20 | 5b 69 66 20 6e 6f 74 20 |.BBEE." |[if not |
|00000fc0| 61 73 73 6f 63 20 73 79 | 6d 62 6f 6c 2d 6e 61 6d |assoc sy|mbol-nam|
|00000fd0| 65 20 66 75 6e 63 74 69 | 6f 6e 20 28 61 64 2d 61 |e functi|on (ad-a|
|00000fe0| 64 76 69 73 65 64 2d 66 | 75 6e 63 74 69 6f 6e 73 |dvised-f|unctions|
|00000ff0| 29 20 73 65 74 71 20 61 | 64 2d 61 64 76 69 73 65 |) setq a|d-advise|
|00001000| 64 2d 66 75 6e 63 74 69 | 6f 6e 73 20 63 6f 6e 73 |d-functi|ons cons|
|00001010| 20 6c 69 73 74 20 28 61 | 64 2d 61 64 76 69 73 65 | list (a|d-advise|
|00001020| 64 2d 66 75 6e 63 74 69 | 6f 6e 73 29 5d 20 38 5d |d-functi|ons)] 8]|
|00001030| 29 29 0a 28 64 65 66 61 | 6c 69 61 73 20 27 61 64 |)).(defa|lias 'ad|
|00001040| 2d 70 6f 70 2d 61 64 76 | 69 73 65 64 2d 66 75 6e |-pop-adv|ised-fun|
|00001050| 63 74 69 6f 6e 20 27 28 | 6d 61 63 72 6f 20 2e 20 |ction '(|macro . |
|00001060| 23 5b 28 66 75 6e 63 74 | 69 6f 6e 29 20 22 c0 c1 |#[(funct|ion) "..|
|00001070| c2 c3 c4 0d 44 c6 42 42 | c7 42 42 45 87 22 20 5b |....D.BB|.BBE." [|
|00001080| 73 65 74 71 20 61 64 2d | 61 64 76 69 73 65 64 2d |setq ad-|advised-|
|00001090| 66 75 6e 63 74 69 6f 6e | 73 20 64 65 6c 71 20 61 |function|s delq a|
|000010a0| 73 73 6f 63 20 73 79 6d | 62 6f 6c 2d 6e 61 6d 65 |ssoc sym|bol-name|
|000010b0| 20 66 75 6e 63 74 69 6f | 6e 20 28 61 64 2d 61 64 | functio|n (ad-ad|
|000010c0| 76 69 73 65 64 2d 66 75 | 6e 63 74 69 6f 6e 73 29 |vised-fu|nctions)|
|000010d0| 20 28 61 64 2d 61 64 76 | 69 73 65 64 2d 66 75 6e | (ad-adv|ised-fun|
|000010e0| 63 74 69 6f 6e 73 29 5d | 20 36 5d 29 29 0a 28 64 |ctions)]| 6])).(d|
|000010f0| 65 66 61 6c 69 61 73 20 | 27 61 64 2d 64 6f 2d 61 |efalias |'ad-do-a|
|00001100| 64 76 69 73 65 64 2d 66 | 75 6e 63 74 69 6f 6e 73 |dvised-f|unctions|
|00001110| 20 27 28 6d 61 63 72 6f | 20 2e 20 23 5b 28 76 61 | '(macro| . #[(va|
|00001120| 72 66 6f 72 6d 20 26 72 | 65 73 74 20 62 6f 64 79 |rform &r|est body|
|00001130| 29 20 22 c0 09 40 c2 09 | 41 40 45 c3 09 40 c4 c5 |) "..@..|A@E..@..|
|00001140| 09 40 44 44 45 0e 06 42 | 42 42 87 22 20 5b 61 64 |.@DDE..B|BB." [ad|
|00001150| 2d 64 6f 6c 69 73 74 20 | 76 61 72 66 6f 72 6d 20 |-dolist |varform |
|00001160| 61 64 2d 61 64 76 69 73 | 65 64 2d 66 75 6e 63 74 |ad-advis|ed-funct|
|00001170| 69 6f 6e 73 20 73 65 74 | 71 20 69 6e 74 65 72 6e |ions set|q intern|
|00001180| 20 63 61 72 20 62 6f 64 | 79 5d 20 37 5d 29 29 0a | car bod|y] 7])).|
|00001190| 28 62 79 74 65 2d 63 6f | 64 65 20 22 c0 c1 4e ac |(byte-co|de "..N.|
|000011a0| 86 c2 c0 c1 c3 23 88 c0 | 87 22 20 5b 61 64 2d 64 |.....#..|." [ad-d|
|000011b0| 6f 2d 61 64 76 69 73 65 | 64 2d 66 75 6e 63 74 69 |o-advise|d-functi|
|000011c0| 6f 6e 73 20 6c 69 73 70 | 2d 69 6e 64 65 6e 74 2d |ons lisp|-indent-|
|000011d0| 68 6f 6f 6b 20 70 75 74 | 20 31 5d 20 34 29 0a 28 |hook put| 1] 4).(|
|000011e0| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 67 65 74 |defalias| 'ad-get|
|000011f0| 2d 61 64 76 69 63 65 2d | 69 6e 66 6f 20 27 28 6d |-advice-|info '(m|
|00001200| 61 63 72 6f 20 2e 20 23 | 5b 28 66 75 6e 63 74 69 |acro . #|[(functi|
|00001210| 6f 6e 29 20 22 c0 09 c2 | 42 42 87 22 20 5b 67 65 |on) "...|BB." [ge|
|00001220| 74 20 66 75 6e 63 74 69 | 6f 6e 20 28 27 61 64 2d |t functi|on ('ad-|
|00001230| 61 64 76 69 63 65 2d 69 | 6e 66 6f 29 5d 20 33 5d |advice-i|nfo)] 3]|
|00001240| 29 29 0a 28 64 65 66 61 | 6c 69 61 73 20 27 61 64 |)).(defa|lias 'ad|
|00001250| 2d 73 65 74 2d 61 64 76 | 69 63 65 2d 69 6e 66 6f |-set-adv|ice-info|
|00001260| 20 27 28 6d 61 63 72 6f | 20 2e 20 23 5b 28 66 75 | '(macro| . #[(fu|
|00001270| 6e 63 74 69 6f 6e 20 61 | 64 76 69 63 65 2d 69 6e |nction a|dvice-in|
|00001280| 66 6f 29 20 22 c0 09 c2 | 0b 46 87 22 20 5b 70 75 |fo) "...|.F." [pu|
|00001290| 74 20 66 75 6e 63 74 69 | 6f 6e 20 27 61 64 2d 61 |t functi|on 'ad-a|
|000012a0| 64 76 69 63 65 2d 69 6e | 66 6f 20 61 64 76 69 63 |dvice-in|fo advic|
|000012b0| 65 2d 69 6e 66 6f 5d 20 | 34 5d 29 29 0a 28 64 65 |e-info] |4])).(de|
|000012c0| 66 61 6c 69 61 73 20 27 | 61 64 2d 63 6f 70 79 2d |falias '|ad-copy-|
|000012d0| 61 64 76 69 63 65 2d 69 | 6e 66 6f 20 27 28 6d 61 |advice-i|nfo '(ma|
|000012e0| 63 72 6f 20 2e 20 23 5b | 28 66 75 6e 63 74 69 6f |cro . #[|(functio|
|000012f0| 6e 29 20 22 c0 c1 5c 6e | c3 42 42 44 87 22 20 5b |n) "..\n|.BBD." [|
|00001300| 61 64 2d 63 6f 70 79 2d | 74 72 65 65 20 67 65 74 |ad-copy-|tree get|
|00001310| 20 66 75 6e 63 74 69 6f | 6e 20 28 27 61 64 2d 61 | functio|n ('ad-a|
|00001320| 64 76 69 63 65 2d 69 6e | 66 6f 29 5d 20 34 5d 29 |dvice-in|fo)] 4])|
|00001330| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00001340| 69 73 2d 61 64 76 69 73 | 65 64 20 27 28 6d 61 63 |is-advis|ed '(mac|
|00001350| 72 6f 20 2e 20 23 5b 28 | 66 75 6e 63 74 69 6f 6e |ro . #[(|function|
|00001360| 29 20 22 c0 09 44 87 22 | 20 5b 61 64 2d 67 65 74 |) "..D."| [ad-get|
|00001370| 2d 61 64 76 69 63 65 2d | 69 6e 66 6f 20 66 75 6e |-advice-|info fun|
|00001380| 63 74 69 6f 6e 5d 20 32 | 5d 29 29 0a 28 64 65 66 |ction] 2|])).(def|
|00001390| 61 6c 69 61 73 20 27 61 | 64 2d 69 6e 69 74 69 61 |alias 'a|d-initia|
|000013a0| 6c 69 7a 65 2d 61 64 76 | 69 63 65 2d 69 6e 66 6f |lize-adv|ice-info|
|000013b0| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 29 20 22 c0 | #[(func|tion) ".|
|000013c0| c1 5c 6e 21 0b 5c 22 ac | 87 c1 5c 6e 21 43 0b 42 |.\n!.\".|..\n!C.B|
|000013d0| 13 c4 5c 6e c5 c6 c7 42 | 43 23 87 22 20 5b 61 73 |..\n...B|C#." [as|
|000013e0| 73 6f 63 20 73 79 6d 62 | 6f 6c 2d 6e 61 6d 65 20 |soc symb|ol-name |
|000013f0| 66 75 6e 63 74 69 6f 6e | 20 61 64 2d 61 64 76 69 |function| ad-advi|
|00001400| 73 65 64 2d 66 75 6e 63 | 74 69 6f 6e 73 20 70 75 |sed-func|tions pu|
|00001410| 74 20 61 64 2d 61 64 76 | 69 63 65 2d 69 6e 66 6f |t ad-adv|ice-info|
|00001420| 20 61 63 74 69 76 65 20 | 6e 69 6c 5d 20 35 5d 29 | active |nil] 5])|
|00001430| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 67 |.(defali|as 'ad-g|
|00001440| 65 74 2d 61 64 76 69 63 | 65 2d 69 6e 66 6f 2d 66 |et-advic|e-info-f|
|00001450| 69 65 6c 64 20 27 28 6d | 61 63 72 6f 20 2e 20 23 |ield '(m|acro . #|
|00001460| 5b 28 66 75 6e 63 74 69 | 6f 6e 20 66 69 65 6c 64 |[(functi|on field|
|00001470| 29 20 22 c0 c1 5c 6e c3 | 0c 44 45 44 87 22 20 5b |) "..\n.|.DED." [|
|00001480| 63 64 72 20 61 73 73 71 | 20 66 69 65 6c 64 20 61 |cdr assq| field a|
|00001490| 64 2d 67 65 74 2d 61 64 | 76 69 63 65 2d 69 6e 66 |d-get-ad|vice-inf|
|000014a0| 6f 20 66 75 6e 63 74 69 | 6f 6e 5d 20 35 5d 29 29 |o functi|on] 5]))|
|000014b0| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 73 |.(defali|as 'ad-s|
|000014c0| 65 74 2d 61 64 76 69 63 | 65 2d 69 6e 66 6f 2d 66 |et-advic|e-info-f|
|000014d0| 69 65 6c 64 20 23 5b 28 | 66 75 6e 63 74 69 6f 6e |ield #[(|function|
|000014e0| 20 66 69 65 6c 64 20 76 | 61 6c 75 65 29 20 22 08 | field v|alue) ".|
|000014f0| c1 4e ad 97 5c 6e 08 c1 | 4e b7 ab 88 5c 6e 08 c1 |.N..\n..|N...\n..|
|00001500| 4e b7 0b a1 87 08 c1 4e | 5c 6e 0b 42 43 a4 87 22 |N......N|\n.BC.."|
|00001510| 20 5b 66 75 6e 63 74 69 | 6f 6e 20 61 64 2d 61 64 | [functi|on ad-ad|
|00001520| 76 69 63 65 2d 69 6e 66 | 6f 20 66 69 65 6c 64 20 |vice-inf|o field |
|00001530| 76 61 6c 75 65 5d 20 33 | 5d 29 0a 28 64 65 66 61 |value] 3|]).(defa|
|00001540| 6c 69 61 73 20 27 61 64 | 2d 69 73 2d 61 63 74 69 |lias 'ad|-is-acti|
|00001550| 76 65 20 23 5b 28 66 75 | 6e 63 74 69 6f 6e 29 20 |ve #[(fu|nction) |
|00001560| 22 c0 09 c2 4e b7 41 87 | 22 20 5b 61 63 74 69 76 |"...N.A.|" [activ|
|00001570| 65 20 66 75 6e 63 74 69 | 6f 6e 20 61 64 2d 61 64 |e functi|on ad-ad|
|00001580| 76 69 63 65 2d 69 6e 66 | 6f 5d 20 33 5d 29 0a 23 |vice-inf|o] 3]).#|
|00001590| 40 32 36 33 20 43 6f 6e | 73 74 72 75 63 74 73 20 |@263 Con|structs |
|000015a0| 73 69 6e 67 6c 65 20 70 | 69 65 63 65 20 6f 66 20 |single p|iece of |
|000015b0| 61 64 76 69 63 65 20 74 | 6f 20 62 65 20 73 74 6f |advice t|o be sto|
|000015c0| 72 65 64 20 69 6e 20 73 | 6f 6d 65 20 61 64 76 69 |red in s|ome advi|
|000015d0| 63 65 2d 69 6e 66 6f 2e | 0a 4e 41 4d 45 20 73 68 |ce-info.|.NAME sh|
|000015e0| 6f 75 6c 64 20 62 65 20 | 61 20 6e 6f 6e 2d 6e 69 |ould be |a non-ni|
|000015f0| 6c 20 73 79 6d 62 6f 6c | 2c 20 50 52 4f 54 45 43 |l symbol|, PROTEC|
|00001600| 54 20 61 6e 64 20 45 4e | 41 42 4c 45 20 73 68 6f |T and EN|ABLE sho|
|00001610| 75 6c 64 20 65 61 63 68 | 20 62 65 0a 65 69 74 68 |uld each| be.eith|
|00001620| 65 72 20 74 20 6f 72 20 | 6e 69 6c 2c 20 61 6e 64 |er t or |nil, and|
|00001630| 20 44 45 46 49 4e 49 54 | 49 4f 4e 20 73 68 6f 75 | DEFINIT|ION shou|
|00001640| 6c 64 20 62 65 20 61 20 | 6c 69 73 74 20 6f 66 20 |ld be a |list of |
|00001650| 74 68 65 20 66 6f 72 6d | 0a 60 28 61 64 76 69 63 |the form|.`(advic|
|00001660| 65 20 6c 61 6d 62 64 61 | 20 41 52 47 4c 49 53 54 |e lambda| ARGLIST|
|00001670| 20 5b 44 4f 43 53 54 52 | 49 4e 47 5d 20 5b 49 4e | [DOCSTR|ING] [IN|
|00001680| 54 45 52 41 43 54 49 56 | 45 2d 46 4f 52 4d 5d 20 |TERACTIV|E-FORM] |
|00001690| 42 4f 44 59 2e 2e 2e 29 | 27 2e 1f 0a 28 64 65 66 |BODY...)|'...(def|
|000016a0| 61 6c 69 61 73 20 27 61 | 64 2d 6d 61 6b 65 2d 61 |alias 'a|d-make-a|
|000016b0| 64 76 69 63 65 20 23 5b | 28 6e 61 6d 65 20 70 72 |dvice #[|(name pr|
|000016c0| 6f 74 65 63 74 20 65 6e | 61 62 6c 65 20 64 65 66 |otect en|able def|
|000016d0| 69 6e 69 74 69 6f 6e 29 | 20 22 08 09 5c 6e 0b 46 |inition)| "..\n.F|
|000016e0| 87 22 20 5b 6e 61 6d 65 | 20 70 72 6f 74 65 63 74 |." [name| protect|
|000016f0| 20 65 6e 61 62 6c 65 20 | 64 65 66 69 6e 69 74 69 | enable |definiti|
|00001700| 6f 6e 5d 20 34 20 28 23 | 24 20 2e 20 35 35 32 35 |on] 4 (#|$ . 5525|
|00001710| 29 5d 29 0a 28 64 65 66 | 61 6c 69 61 73 20 27 61 |)]).(def|alias 'a|
|00001720| 64 2d 61 64 76 69 63 65 | 2d 6e 61 6d 65 20 27 28 |d-advice|-name '(|
|00001730| 6d 61 63 72 6f 20 2e 20 | 23 5b 28 61 64 76 69 63 |macro . |#[(advic|
|00001740| 65 29 20 22 c0 09 44 87 | 22 20 5b 63 61 72 20 61 |e) "..D.|" [car a|
|00001750| 64 76 69 63 65 5d 20 32 | 5d 29 29 0a 28 64 65 66 |dvice] 2|])).(def|
|00001760| 61 6c 69 61 73 20 27 61 | 64 2d 61 64 76 69 63 65 |alias 'a|d-advice|
|00001770| 2d 70 72 6f 74 65 63 74 | 65 64 20 27 28 6d 61 63 |-protect|ed '(mac|
|00001780| 72 6f 20 2e 20 23 5b 28 | 61 64 76 69 63 65 29 20 |ro . #[(|advice) |
|00001790| 22 c0 c1 5c 6e 45 87 22 | 20 5b 6e 74 68 20 31 20 |"..\nE."| [nth 1 |
|000017a0| 61 64 76 69 63 65 5d 20 | 33 5d 29 29 0a 28 64 65 |advice] |3])).(de|
|000017b0| 66 61 6c 69 61 73 20 27 | 61 64 2d 61 64 76 69 63 |falias '|ad-advic|
|000017c0| 65 2d 65 6e 61 62 6c 65 | 64 20 27 28 6d 61 63 72 |e-enable|d '(macr|
|000017d0| 6f 20 2e 20 23 5b 28 61 | 64 76 69 63 65 29 20 22 |o . #[(a|dvice) "|
|000017e0| c0 c1 5c 6e 45 87 22 20 | 5b 6e 74 68 20 32 20 61 |..\nE." |[nth 2 a|
|000017f0| 64 76 69 63 65 5d 20 33 | 5d 29 29 0a 28 64 65 66 |dvice] 3|])).(def|
|00001800| 61 6c 69 61 73 20 27 61 | 64 2d 61 64 76 69 63 65 |alias 'a|d-advice|
|00001810| 2d 64 65 66 69 6e 69 74 | 69 6f 6e 20 27 28 6d 61 |-definit|ion '(ma|
|00001820| 63 72 6f 20 2e 20 23 5b | 28 61 64 76 69 63 65 29 |cro . #[|(advice)|
|00001830| 20 22 c0 c1 5c 6e 45 87 | 22 20 5b 6e 74 68 20 33 | "..\nE.|" [nth 3|
|00001840| 20 61 64 76 69 63 65 5d | 20 33 5d 29 29 0a 28 64 | advice]| 3])).(d|
|00001850| 65 66 61 6c 69 61 73 20 | 27 61 64 2d 61 64 76 69 |efalias |'ad-advi|
|00001860| 63 65 2d 73 65 74 2d 65 | 6e 61 62 6c 65 64 20 23 |ce-set-e|nabled #|
|00001870| 5b 28 61 64 76 69 63 65 | 20 66 6c 61 67 29 20 22 |[(advice| flag) "|
|00001880| 08 41 41 09 a0 87 22 20 | 5b 61 64 76 69 63 65 20 |.AA..." |[advice |
|00001890| 66 6c 61 67 5d 20 32 5d | 29 0a 28 64 65 66 61 6c |flag] 2]|).(defal|
|000018a0| 69 61 73 20 27 61 64 2d | 63 6c 61 73 73 2d 70 20 |ias 'ad-|class-p |
|000018b0| 23 5b 28 74 68 69 6e 67 | 29 20 22 08 09 73 87 22 |#[(thing|) "..s."|
|000018c0| 20 5b 74 68 69 6e 67 20 | 61 64 2d 61 64 76 69 63 | [thing |ad-advic|
|000018d0| 65 2d 63 6c 61 73 73 65 | 73 5d 20 32 5d 29 0a 28 |e-classe|s] 2]).(|
|000018e0| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 6e 61 6d |defalias| 'ad-nam|
|000018f0| 65 2d 70 20 23 5b 28 74 | 68 69 6e 67 29 20 22 08 |e-p #[(t|hing) ".|
|00001900| ad 82 08 39 87 22 20 5b | 74 68 69 6e 67 5d 20 31 |...9." [|thing] 1|
|00001910| 5d 29 0a 28 64 65 66 61 | 6c 69 61 73 20 27 61 64 |]).(defa|lias 'ad|
|00001920| 2d 70 6f 73 69 74 69 6f | 6e 2d 70 20 23 5b 28 74 |-positio|n-p #[(t|
|00001930| 68 69 6e 67 29 20 22 c0 | 09 21 ae 83 09 c2 73 87 |hing) ".|.!....s.|
|00001940| 22 20 5b 6e 61 74 6e 75 | 6d 70 20 74 68 69 6e 67 |" [natnu|mp thing|
|00001950| 20 28 66 69 72 73 74 20 | 6c 61 73 74 29 5d 20 32 | (first |last)] 2|
|00001960| 5d 29 0a 28 62 79 74 65 | 2d 63 6f 64 65 20 22 c0 |]).(byte|-code ".|
|00001970| c1 21 ac 82 c2 11 c1 0b | 42 13 c0 87 22 20 5b 62 |.!......|B..." [b|
|00001980| 6f 75 6e 64 70 20 61 64 | 2d 61 64 76 69 63 65 2d |oundp ad|-advice-|
|00001990| 63 6c 61 73 73 65 73 20 | 28 62 65 66 6f 72 65 20 |classes |(before |
|000019a0| 61 72 6f 75 6e 64 20 61 | 66 74 65 72 20 61 63 74 |around a|fter act|
|000019b0| 69 76 61 74 69 6f 6e 20 | 64 65 61 63 74 69 76 61 |ivation |deactiva|
|000019c0| 74 69 6f 6e 29 20 63 75 | 72 72 65 6e 74 2d 6c 6f |tion) cu|rrent-lo|
|000019d0| 61 64 2d 6c 69 73 74 5d | 20 32 29 0a 28 64 65 66 |ad-list]| 2).(def|
|000019e0| 61 6c 69 61 73 20 27 61 | 64 2d 68 61 73 2d 65 6e |alias 'a|d-has-en|
|000019f0| 61 62 6c 65 64 2d 61 64 | 76 69 63 65 20 23 5b 28 |abled-ad|vice #[(|
|00001a00| 66 75 6e 63 74 69 6f 6e | 20 63 6c 61 73 73 29 20 |function| class) |
|00001a10| 22 c0 c1 8d 87 22 20 5b | 61 64 2d 64 4f 2d 65 58 |"...." [|ad-dO-eX|
|00001a20| 69 54 20 28 62 79 74 65 | 2d 63 6f 64 65 20 22 08 |iT (byte|-code ".|
|00001a30| 09 c2 4e b7 41 c3 1c 89 | 1d ab 93 0d 40 14 c6 0c |..N.A...|....@...|
|00001a40| 38 ab 85 c7 c8 c9 5c 22 | 88 0d 41 89 15 ac 6d 2a |8.....\"|..A...m*|
|00001a50| c3 87 22 20 5b 63 6c 61 | 73 73 20 66 75 6e 63 74 |.." [cla|ss funct|
|00001a60| 69 6f 6e 20 61 64 2d 61 | 64 76 69 63 65 2d 69 6e |ion ad-a|dvice-in|
|00001a70| 66 6f 20 6e 69 6c 20 61 | 64 76 69 63 65 20 61 64 |fo nil a|dvice ad|
|00001a80| 2d 64 4f 2d 76 41 72 20 | 32 20 74 68 72 6f 77 20 |-dO-vAr |2 throw |
|00001a90| 61 64 2d 64 4f 2d 65 58 | 69 54 20 74 5d 20 34 29 |ad-dO-eX|iT t] 4)|
|00001aa0| 5d 20 32 5d 29 0a 28 64 | 65 66 61 6c 69 61 73 20 |] 2]).(d|efalias |
|00001ab0| 27 61 64 2d 68 61 73 2d | 72 65 64 65 66 69 6e 69 |'ad-has-|redefini|
|00001ac0| 6e 67 2d 61 64 76 69 63 | 65 20 23 5b 28 66 75 6e |ng-advic|e #[(fun|
|00001ad0| 63 74 69 6f 6e 29 20 22 | 08 c1 4e ad 90 c2 08 c3 |ction) "|..N.....|
|00001ae0| 5c 22 ae 8a c2 08 c4 5c | 22 ae 84 c2 08 c5 5c 22 |\".....\|".....\"|
|00001af0| 87 22 20 5b 66 75 6e 63 | 74 69 6f 6e 20 61 64 2d |." [func|tion ad-|
|00001b00| 61 64 76 69 63 65 2d 69 | 6e 66 6f 20 61 64 2d 68 |advice-i|nfo ad-h|
|00001b10| 61 73 2d 65 6e 61 62 6c | 65 64 2d 61 64 76 69 63 |as-enabl|ed-advic|
|00001b20| 65 20 62 65 66 6f 72 65 | 20 61 72 6f 75 6e 64 20 |e before| around |
|00001b30| 61 66 74 65 72 5d 20 33 | 5d 29 0a 28 64 65 66 61 |after] 3|]).(defa|
|00001b40| 6c 69 61 73 20 27 61 64 | 2d 68 61 73 2d 61 6e 79 |lias 'ad|-has-any|
|00001b50| 2d 61 64 76 69 63 65 20 | 23 5b 28 66 75 6e 63 74 |-advice |#[(funct|
|00001b60| 69 6f 6e 29 20 22 08 c1 | 4e ad 83 c2 c3 8d 87 22 |ion) "..|N......"|
|00001b70| 20 5b 66 75 6e 63 74 69 | 6f 6e 20 61 64 2d 61 64 | [functi|on ad-ad|
|00001b80| 76 69 63 65 2d 69 6e 66 | 6f 20 61 64 2d 64 4f 2d |vice-inf|o ad-dO-|
|00001b90| 65 58 69 54 20 28 62 79 | 74 65 2d 63 6f 64 65 20 |eXiT (by|te-code |
|00001ba0| 22 08 c1 1a 89 1b ab 96 | 0b 40 89 12 0c c5 4e b7 |".......|.@....N.|
|00001bb0| 41 ab 85 c6 c7 c8 5c 22 | 88 0b 41 89 13 ac 6a 2a |A.....\"|..A...j*|
|00001bc0| c1 87 22 20 5b 61 64 2d | 61 64 76 69 63 65 2d 63 |.." [ad-|advice-c|
|00001bd0| 6c 61 73 73 65 73 20 6e | 69 6c 20 63 6c 61 73 73 |lasses n|il class|
|00001be0| 20 61 64 2d 64 4f 2d 76 | 41 72 20 66 75 6e 63 74 | ad-dO-v|Ar funct|
|00001bf0| 69 6f 6e 20 61 64 2d 61 | 64 76 69 63 65 2d 69 6e |ion ad-a|dvice-in|
|00001c00| 66 6f 20 74 68 72 6f 77 | 20 61 64 2d 64 4f 2d 65 |fo throw| ad-dO-e|
|00001c10| 58 69 54 20 74 5d 20 34 | 29 5d 20 32 5d 29 0a 28 |XiT t] 4|)] 2]).(|
|00001c20| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 67 65 74 |defalias| 'ad-get|
|00001c30| 2d 65 6e 61 62 6c 65 64 | 2d 61 64 76 69 63 65 73 |-enabled|-advices|
|00001c40| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 20 63 6c 61 | #[(func|tion cla|
|00001c50| 73 73 29 20 22 c0 19 5c | 6e 0b c4 4e b7 41 c0 1d |ss) "..\|n..N.A..|
|00001c60| 89 1e 06 ab 95 0e 06 40 | 15 c7 0d 38 ab 84 0d 09 |.......@|...8....|
|00001c70| 42 11 0e 06 41 89 16 06 | ac 6b 2a c8 09 21 29 87 |B...A...|.k*..!).|
|00001c80| 22 20 5b 6e 69 6c 20 65 | 6e 61 62 6c 65 64 2d 61 |" [nil e|nabled-a|
|00001c90| 64 76 69 63 65 73 20 63 | 6c 61 73 73 20 66 75 6e |dvices c|lass fun|
|00001ca0| 63 74 69 6f 6e 20 61 64 | 2d 61 64 76 69 63 65 2d |ction ad|-advice-|
|00001cb0| 69 6e 66 6f 20 61 64 76 | 69 63 65 20 61 64 2d 64 |info adv|ice ad-d|
|00001cc0| 4f 2d 76 41 72 20 32 20 | 72 65 76 65 72 73 65 5d |O-vAr 2 |reverse]|
|00001cd0| 20 34 5d 29 0a 23 40 37 | 32 20 41 75 74 6f 6d 61 | 4]).#@7|2 Automa|
|00001ce0| 74 69 63 20 61 64 76 69 | 63 65 20 61 63 74 69 76 |tic advi|ce activ|
|00001cf0| 61 74 69 6f 6e 20 69 73 | 20 64 69 73 61 62 6c 65 |ation is| disable|
|00001d00| 64 2e 20 60 61 64 2d 73 | 74 61 72 74 2d 61 64 76 |d. `ad-s|tart-adv|
|00001d10| 69 63 65 27 20 65 6e 61 | 62 6c 65 73 20 69 74 2e |ice' ena|bles it.|
|00001d20| 1f 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |..(defal|ias 'ad-|
|00001d30| 61 63 74 69 76 61 74 65 | 20 23 5b 28 66 75 6e 63 |activate| #[(func|
|00001d40| 74 69 6f 6e 20 26 6f 70 | 74 69 6f 6e 61 6c 20 63 |tion &op|tional c|
|00001d50| 6f 6d 70 69 6c 65 29 20 | 22 c0 87 22 20 5b 6e 69 |ompile) |".." [ni|
|00001d60| 6c 5d 20 31 20 28 23 24 | 20 2e 20 37 33 38 36 29 |l] 1 (#$| . 7386)|
|00001d70| 5d 29 0a 23 40 37 32 20 | 41 75 74 6f 6d 61 74 69 |]).#@72 |Automati|
|00001d80| 63 20 61 64 76 69 63 65 | 20 61 63 74 69 76 61 74 |c advice| activat|
|00001d90| 69 6f 6e 20 69 73 20 64 | 69 73 61 62 6c 65 64 2e |ion is d|isabled.|
|00001da0| 20 60 61 64 2d 73 74 61 | 72 74 2d 61 64 76 69 63 | `ad-sta|rt-advic|
|00001db0| 65 27 20 65 6e 61 62 6c | 65 73 20 69 74 2e 1f 0a |e' enabl|es it...|
|00001dc0| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 61 63 |(defalia|s 'ad-ac|
|00001dd0| 74 69 76 61 74 65 2d 6f | 66 66 20 23 5b 28 66 75 |tivate-o|ff #[(fu|
|00001de0| 6e 63 74 69 6f 6e 20 26 | 6f 70 74 69 6f 6e 61 6c |nction &|optional|
|00001df0| 20 63 6f 6d 70 69 6c 65 | 29 20 22 c0 87 22 20 5b | compile|) ".." [|
|00001e00| 6e 69 6c 5d 20 31 20 28 | 23 24 20 2e 20 37 35 34 |nil] 1 (|#$ . 754|
|00001e10| 34 29 5d 29 0a 28 62 79 | 74 65 2d 63 6f 64 65 20 |4)]).(by|te-code |
|00001e20| 22 c0 c1 21 ac 82 c2 11 | c1 0b 42 13 c0 87 22 20 |"..!....|..B..." |
|00001e30| 5b 62 6f 75 6e 64 70 20 | 61 64 2d 61 63 74 69 76 |[boundp |ad-activ|
|00001e40| 61 74 65 2d 6f 6e 2d 74 | 6f 70 2d 6c 65 76 65 6c |ate-on-t|op-level|
|00001e50| 20 74 20 63 75 72 72 65 | 6e 74 2d 6c 6f 61 64 2d | t curre|nt-load-|
|00001e60| 6c 69 73 74 5d 20 32 29 | 0a 28 64 65 66 61 6c 69 |list] 2)|.(defali|
|00001e70| 61 73 20 27 61 64 2d 77 | 69 74 68 2d 61 75 74 6f |as 'ad-w|ith-auto|
|00001e80| 2d 61 63 74 69 76 61 74 | 69 6f 6e 2d 64 69 73 61 |-activat|ion-disa|
|00001e90| 62 6c 65 64 20 27 28 6d | 61 63 72 6f 20 2e 20 23 |bled '(m|acro . #|
|00001ea0| 5b 28 26 72 65 73 74 20 | 62 6f 64 79 29 20 22 c0 |[(&rest |body) ".|
|00001eb0| c1 5c 6e 42 42 87 22 20 | 5b 6c 65 74 20 28 28 61 |.\nBB." |[let ((a|
|00001ec0| 64 2d 61 63 74 69 76 61 | 74 65 2d 6f 6e 2d 74 6f |d-activa|te-on-to|
|00001ed0| 70 2d 6c 65 76 65 6c 20 | 6e 69 6c 29 29 20 62 6f |p-level |nil)) bo|
|00001ee0| 64 79 5d 20 33 5d 29 29 | 0a 28 64 65 66 61 6c 69 |dy] 3]))|.(defali|
|00001ef0| 61 73 20 27 61 64 2d 73 | 61 66 65 2d 66 73 65 74 |as 'ad-s|afe-fset|
|00001f00| 20 23 5b 28 73 79 6d 62 | 6f 6c 20 64 65 66 69 6e | #[(symb|ol defin|
|00001f10| 69 74 69 6f 6e 29 20 22 | c0 19 5c 6e 0b 4d 29 87 |ition) "|..\n.M).|
|00001f20| 22 20 5b 6e 69 6c 20 61 | 64 2d 61 63 74 69 76 61 |" [nil a|d-activa|
|00001f30| 74 65 2d 6f 6e 2d 74 6f | 70 2d 6c 65 76 65 6c 20 |te-on-to|p-level |
|00001f40| 73 79 6d 62 6f 6c 20 64 | 65 66 69 6e 69 74 69 6f |symbol d|efinitio|
|00001f50| 6e 5d 20 32 5d 29 0a 28 | 64 65 66 61 6c 69 61 73 |n] 2]).(|defalias|
|00001f60| 20 27 61 64 2d 6d 61 6b | 65 2d 6f 72 69 67 6e 61 | 'ad-mak|e-origna|
|00001f70| 6d 65 20 23 5b 28 66 75 | 6e 63 74 69 6f 6e 29 20 |me #[(fu|nction) |
|00001f80| 22 c0 c1 c2 0b 5c 22 21 | 87 22 20 5b 69 6e 74 65 |"....\"!|." [inte|
|00001f90| 72 6e 20 66 6f 72 6d 61 | 74 20 22 61 64 2d 4f 72 |rn forma|t "ad-Or|
|00001fa0| 69 67 2d 25 73 22 20 66 | 75 6e 63 74 69 6f 6e 5d |ig-%s" f|unction]|
|00001fb0| 20 34 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 4]).(de|falias '|
|00001fc0| 61 64 2d 67 65 74 2d 6f | 72 69 67 2d 64 65 66 69 |ad-get-o|rig-defi|
|00001fd0| 6e 69 74 69 6f 6e 20 27 | 28 6d 61 63 72 6f 20 2e |nition '|(macro .|
|00001fe0| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 29 20 22 c0 | #[(func|tion) ".|
|00001ff0| c1 c2 0b c4 42 42 44 43 | c5 42 42 87 22 20 5b 6c |....BBDC|.BB." [l|
|00002000| 65 74 20 6f 72 69 67 6e | 61 6d 65 20 61 64 2d 67 |et orign|ame ad-g|
|00002010| 65 74 2d 61 64 76 69 63 | 65 2d 69 6e 66 6f 2d 66 |et-advic|e-info-f|
|00002020| 69 65 6c 64 20 66 75 6e | 63 74 69 6f 6e 20 28 27 |ield fun|ction ('|
|00002030| 6f 72 69 67 6e 61 6d 65 | 29 20 28 28 69 66 20 28 |origname|) ((if (|
|00002040| 66 62 6f 75 6e 64 70 20 | 6f 72 69 67 6e 61 6d 65 |fboundp |origname|
|00002050| 29 20 28 73 79 6d 62 6f | 6c 2d 66 75 6e 63 74 69 |) (symbo|l-functi|
|00002060| 6f 6e 20 6f 72 69 67 6e | 61 6d 65 29 29 29 5d 20 |on orign|ame)))] |
|00002070| 35 5d 29 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 |5])).(de|falias '|
|00002080| 61 64 2d 73 65 74 2d 6f | 72 69 67 2d 64 65 66 69 |ad-set-o|rig-defi|
|00002090| 6e 69 74 69 6f 6e 20 27 | 28 6d 61 63 72 6f 20 2e |nition '|(macro .|
|000020a0| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 20 64 65 66 | #[(func|tion def|
|000020b0| 69 6e 69 74 69 6f 6e 29 | 20 22 c0 c1 5c 6e 45 87 |inition)| "..\nE.|
|000020c0| 22 20 5b 61 64 2d 73 61 | 66 65 2d 66 73 65 74 20 |" [ad-sa|fe-fset |
|000020d0| 28 61 64 2d 67 65 74 2d | 61 64 76 69 63 65 2d 69 |(ad-get-|advice-i|
|000020e0| 6e 66 6f 2d 66 69 65 6c | 64 20 66 75 6e 63 74 69 |nfo-fiel|d functi|
|000020f0| 6f 6e 20 27 6f 72 69 67 | 6e 61 6d 65 29 20 64 65 |on 'orig|name) de|
|00002100| 66 69 6e 69 74 69 6f 6e | 5d 20 33 5d 29 29 0a 28 |finition|] 3])).(|
|00002110| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 63 6c 65 |defalias| 'ad-cle|
|00002120| 61 72 2d 6f 72 69 67 2d | 64 65 66 69 6e 69 74 69 |ar-orig-|definiti|
|00002130| 6f 6e 20 27 28 6d 61 63 | 72 6f 20 2e 20 23 5b 28 |on '(mac|ro . #[(|
|00002140| 66 75 6e 63 74 69 6f 6e | 29 20 22 c0 c1 5c 6e c3 |function|) "..\n.|
|00002150| 42 42 44 87 22 20 5b 66 | 6d 61 6b 75 6e 62 6f 75 |BBD." [f|makunbou|
|00002160| 6e 64 20 61 64 2d 67 65 | 74 2d 61 64 76 69 63 65 |nd ad-ge|t-advice|
|00002170| 2d 69 6e 66 6f 2d 66 69 | 65 6c 64 20 66 75 6e 63 |-info-fi|eld func|
|00002180| 74 69 6f 6e 20 28 27 6f | 72 69 67 6e 61 6d 65 29 |tion ('o|rigname)|
|00002190| 5d 20 34 5d 29 29 0a 28 | 64 65 66 61 6c 69 61 73 |] 4])).(|defalias|
|000021a0| 20 27 61 64 2d 72 65 61 | 64 2d 61 64 76 69 73 65 | 'ad-rea|d-advise|
|000021b0| 64 2d 66 75 6e 63 74 69 | 6f 6e 20 23 5b 28 26 6f |d-functi|on #[(&o|
|000021c0| 70 74 69 6f 6e 61 6c 20 | 70 72 6f 6d 70 74 20 70 |ptional |prompt p|
|000021d0| 72 65 64 69 63 61 74 65 | 20 64 65 66 61 75 6c 74 |redicate| default|
|000021e0| 29 20 22 08 ac 84 c1 c2 | 21 88 0b ae 89 c4 c5 8d |) ".....|!.......|
|000021f0| ae 84 c1 c6 c7 5c 22 13 | 0e 08 1e 09 ca cb cc 0e |.....\".|........|
|00002200| 0d ae 81 ce 0b 23 08 0e | 08 ad 81 cf d0 24 89 1e |.....#..|.....$..|
|00002210| 11 d2 6b ab 8e 0b d3 4e | ab 83 0b aa 8a c1 d4 0b |..k....N|........|
|00002220| 5c 22 aa 84 d5 0e 11 21 | 2a 87 22 20 5b 61 64 2d |\".....!|*." [ad-|
|00002230| 61 64 76 69 73 65 64 2d | 66 75 6e 63 74 69 6f 6e |advised-|function|
|00002240| 73 20 65 72 72 6f 72 20 | 22 61 64 2d 72 65 61 64 |s error |"ad-read|
|00002250| 2d 61 64 76 69 73 65 64 | 2d 66 75 6e 63 74 69 6f |-advised|-functio|
|00002260| 6e 3a 20 54 68 65 72 65 | 20 61 72 65 20 6e 6f 20 |n: There| are no |
|00002270| 61 64 76 69 73 65 64 20 | 66 75 6e 63 74 69 6f 6e |advised |function|
|00002280| 73 22 20 64 65 66 61 75 | 6c 74 20 61 64 2d 64 4f |s" defau|lt ad-dO|
|00002290| 2d 65 58 69 54 20 28 62 | 79 74 65 2d 63 6f 64 65 |-eXiT (b|yte-code|
|000022a0| 20 22 08 c1 1a 89 1b ab | 9b 0b 40 12 c4 5c 6e 40 | "......|..@..\n@|
|000022b0| 21 12 0d ab 85 0d 5c 6e | 21 ab 85 c6 c7 5c 6e 5c |!.....\n|!....\n\|
|000022c0| 22 88 0b 41 89 13 ac 65 | 2a c1 87 22 20 5b 61 64 |"..A...e|*.." [ad|
|000022d0| 2d 61 64 76 69 73 65 64 | 2d 66 75 6e 63 74 69 6f |-advised|-functio|
|000022e0| 6e 73 20 6e 69 6c 20 66 | 75 6e 63 74 69 6f 6e 20 |ns nil f|unction |
|000022f0| 61 64 2d 64 4f 2d 76 41 | 72 20 69 6e 74 65 72 6e |ad-dO-vA|r intern|
|00002300| 20 70 72 65 64 69 63 61 | 74 65 20 74 68 72 6f 77 | predica|te throw|
|00002310| 20 61 64 2d 64 4f 2d 65 | 58 69 54 5d 20 34 29 20 | ad-dO-e|XiT] 4) |
|00002320| 22 61 64 2d 72 65 61 64 | 2d 61 64 76 69 73 65 64 |"ad-read|-advised|
|00002330| 2d 66 75 6e 63 74 69 6f | 6e 3a 20 25 73 22 20 22 |-functio|n: %s" "|
|00002340| 54 68 65 72 65 20 61 72 | 65 20 6e 6f 20 71 75 61 |There ar|e no qua|
|00002350| 6c 69 66 79 69 6e 67 20 | 61 64 76 69 73 65 64 20 |lifying |advised |
|00002360| 66 75 6e 63 74 69 6f 6e | 73 22 20 70 72 65 64 69 |function|s" predi|
|00002370| 63 61 74 65 20 61 64 2d | 70 52 65 44 69 43 61 54 |cate ad-|pReDiCaT|
|00002380| 65 20 63 6f 6d 70 6c 65 | 74 69 6e 67 2d 72 65 61 |e comple|ting-rea|
|00002390| 64 20 66 6f 72 6d 61 74 | 20 22 25 73 28 64 65 66 |d format| "%s(def|
|000023a0| 61 75 6c 74 20 25 73 29 | 20 22 20 70 72 6f 6d 70 |ault %s)| " promp|
|000023b0| 74 20 22 46 75 6e 63 74 | 69 6f 6e 3a 20 22 20 23 |t "Funct|ion: " #|
|000023c0| 5b 28 66 75 6e 63 74 69 | 6f 6e 29 20 22 08 c1 5c |[(functi|on) "..\|
|000023d0| 6e 40 21 21 87 22 20 5b | 61 64 2d 70 52 65 44 69 |n@!!." [|ad-pReDi|
|000023e0| 43 61 54 65 20 69 6e 74 | 65 72 6e 20 66 75 6e 63 |CaTe int|ern func|
|000023f0| 74 69 6f 6e 5d 20 33 5d | 20 74 20 66 75 6e 63 74 |tion] 3]| t funct|
|00002400| 69 6f 6e 20 22 22 20 61 | 64 2d 61 64 76 69 63 65 |ion "" a|d-advice|
|00002410| 2d 69 6e 66 6f 20 22 61 | 64 2d 72 65 61 64 2d 61 |-info "a|d-read-a|
|00002420| 64 76 69 73 65 64 2d 66 | 75 6e 63 74 69 6f 6e 3a |dvised-f|unction:|
|00002430| 20 60 25 73 27 20 69 73 | 20 6e 6f 74 20 61 64 76 | `%s' is| not adv|
|00002440| 69 73 65 64 22 20 69 6e | 74 65 72 6e 5d 20 36 5d |ised" in|tern] 6]|
|00002450| 29 0a 28 62 79 74 65 2d | 63 6f 64 65 20 22 c0 c1 |).(byte-|code "..|
|00002460| 21 ac 85 c2 c3 0c 5c 22 | 11 c1 0d 42 15 c0 87 22 |!.....\"|...B..."|
|00002470| 20 5b 62 6f 75 6e 64 70 | 20 61 64 2d 61 64 76 69 | [boundp| ad-advi|
|00002480| 63 65 2d 63 6c 61 73 73 | 2d 63 6f 6d 70 6c 65 74 |ce-class|-complet|
|00002490| 69 6f 6e 2d 74 61 62 6c | 65 20 6d 61 70 63 61 72 |ion-tabl|e mapcar|
|000024a0| 20 23 5b 28 63 6c 61 73 | 73 29 20 22 c0 09 21 43 | #[(clas|s) "..!C|
|000024b0| 87 22 20 5b 73 79 6d 62 | 6f 6c 2d 6e 61 6d 65 20 |." [symb|ol-name |
|000024c0| 63 6c 61 73 73 5d 20 32 | 5d 20 61 64 2d 61 64 76 |class] 2|] ad-adv|
|000024d0| 69 63 65 2d 63 6c 61 73 | 73 65 73 20 63 75 72 72 |ice-clas|ses curr|
|000024e0| 65 6e 74 2d 6c 6f 61 64 | 2d 6c 69 73 74 5d 20 33 |ent-load|-list] 3|
|000024f0| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00002500| 72 65 61 64 2d 61 64 76 | 69 63 65 2d 63 6c 61 73 |read-adv|ice-clas|
|00002510| 73 20 23 5b 28 66 75 6e | 63 74 69 6f 6e 20 26 6f |s #[(fun|ction &o|
|00002520| 70 74 69 6f 6e 61 6c 20 | 70 72 6f 6d 70 74 20 64 |ptional |prompt d|
|00002530| 65 66 61 75 6c 74 29 20 | 22 08 ae 89 c1 c2 8d ae |efault) |".......|
|00002540| 84 c3 c4 0d 5c 22 10 c6 | c7 c8 0e 09 ae 81 ca 08 |....\"..|........|
|00002550| 23 0e 0b cc cd 24 89 1e | 0e cf 6b ab 83 08 aa 84 |#....$..|..k.....|
|00002560| d0 0e 0e 21 29 87 22 20 | 5b 64 65 66 61 75 6c 74 |...!)." |[default|
|00002570| 20 61 64 2d 64 4f 2d 65 | 58 69 54 20 28 62 79 74 | ad-dO-e|XiT (byt|
|00002580| 65 2d 63 6f 64 65 20 22 | 08 c1 1a 89 1b ab 96 0b |e-code "|........|
|00002590| 40 89 12 0c c5 4e b7 41 | ab 85 c6 c7 5c 6e 5c 22 |@....N.A|....\n\"|
|000025a0| 88 0b 41 89 13 ac 6a 2a | c1 87 22 20 5b 61 64 2d |..A...j*|.." [ad-|
|000025b0| 61 64 76 69 63 65 2d 63 | 6c 61 73 73 65 73 20 6e |advice-c|lasses n|
|000025c0| 69 6c 20 63 6c 61 73 73 | 20 61 64 2d 64 4f 2d 76 |il class| ad-dO-v|
|000025d0| 41 72 20 66 75 6e 63 74 | 69 6f 6e 20 61 64 2d 61 |Ar funct|ion ad-a|
|000025e0| 64 76 69 63 65 2d 69 6e | 66 6f 20 74 68 72 6f 77 |dvice-in|fo throw|
|000025f0| 20 61 64 2d 64 4f 2d 65 | 58 69 54 5d 20 34 29 20 | ad-dO-e|XiT] 4) |
|00002600| 65 72 72 6f 72 20 22 61 | 64 2d 72 65 61 64 2d 61 |error "a|d-read-a|
|00002610| 64 76 69 63 65 2d 63 6c | 61 73 73 3a 20 60 25 73 |dvice-cl|ass: `%s|
|00002620| 27 20 68 61 73 20 6e 6f | 20 61 64 76 69 63 65 73 |' has no| advices|
|00002630| 22 20 66 75 6e 63 74 69 | 6f 6e 20 63 6f 6d 70 6c |" functi|on compl|
|00002640| 65 74 69 6e 67 2d 72 65 | 61 64 20 66 6f 72 6d 61 |eting-re|ad forma|
|00002650| 74 20 22 25 73 28 64 65 | 66 61 75 6c 74 20 25 73 |t "%s(de|fault %s|
|00002660| 29 20 22 20 70 72 6f 6d | 70 74 20 22 43 6c 61 73 |) " prom|pt "Clas|
|00002670| 73 3a 20 22 20 61 64 2d | 61 64 76 69 63 65 2d 63 |s: " ad-|advice-c|
|00002680| 6c 61 73 73 2d 63 6f 6d | 70 6c 65 74 69 6f 6e 2d |lass-com|pletion-|
|00002690| 74 61 62 6c 65 20 6e 69 | 6c 20 74 20 63 6c 61 73 |table ni|l t clas|
|000026a0| 73 20 22 22 20 69 6e 74 | 65 72 6e 5d 20 36 5d 29 |s "" int|ern] 6])|
|000026b0| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 72 |.(defali|as 'ad-r|
|000026c0| 65 61 64 2d 61 64 76 69 | 63 65 2d 6e 61 6d 65 20 |ead-advi|ce-name |
|000026d0| 23 5b 28 66 75 6e 63 74 | 69 6f 6e 20 63 6c 61 73 |#[(funct|ion clas|
|000026e0| 73 20 26 6f 70 74 69 6f | 6e 61 6c 20 70 72 6f 6d |s &optio|nal prom|
|000026f0| 70 74 29 20 22 c0 c1 5c | 6e 0b c4 4e b7 41 5c 22 |pt) "..\|n..N.A\"|
|00002700| 89 1d ac 87 c6 c7 0b 5c | 6e 23 aa 83 0d 40 40 1e |.......\|n#...@@.|
|00002710| 08 c9 ca 0e 0b ae 81 cc | 0e 08 23 1e 0b cd 0e 0b |........|..#.....|
|00002720| 0d ce cf 24 89 1e 10 d1 | 6b ab 86 d2 0e 08 21 aa |...$....|k.....!.|
|00002730| 84 d2 0e 10 21 2c 87 22 | 20 5b 6d 61 70 63 61 72 |....!,."| [mapcar|
|00002740| 20 23 5b 28 61 64 76 69 | 63 65 29 20 22 c0 09 40 | #[(advi|ce) "..@|
|00002750| 21 43 87 22 20 5b 73 79 | 6d 62 6f 6c 2d 6e 61 6d |!C." [sy|mbol-nam|
|00002760| 65 20 61 64 76 69 63 65 | 5d 20 32 5d 20 63 6c 61 |e advice|] 2] cla|
|00002770| 73 73 20 66 75 6e 63 74 | 69 6f 6e 20 61 64 2d 61 |ss funct|ion ad-a|
|00002780| 64 76 69 63 65 2d 69 6e | 66 6f 20 6e 61 6d 65 2d |dvice-in|fo name-|
|00002790| 63 6f 6d 70 6c 65 74 69 | 6f 6e 2d 74 61 62 6c 65 |completi|on-table|
|000027a0| 20 65 72 72 6f 72 20 22 | 61 64 2d 72 65 61 64 2d | error "|ad-read-|
|000027b0| 61 64 76 69 63 65 2d 6e | 61 6d 65 3a 20 60 25 73 |advice-n|ame: `%s|
|000027c0| 27 20 68 61 73 20 6e 6f | 20 25 73 20 61 64 76 69 |' has no| %s advi|
|000027d0| 63 65 22 20 64 65 66 61 | 75 6c 74 20 66 6f 72 6d |ce" defa|ult form|
|000027e0| 61 74 20 22 25 73 28 64 | 65 66 61 75 6c 74 20 25 |at "%s(d|efault %|
|000027f0| 73 29 20 22 20 70 72 6f | 6d 70 74 20 22 4e 61 6d |s) " pro|mpt "Nam|
|00002800| 65 3a 20 22 20 63 6f 6d | 70 6c 65 74 69 6e 67 2d |e: " com|pleting-|
|00002810| 72 65 61 64 20 6e 69 6c | 20 74 20 6e 61 6d 65 20 |read nil| t name |
|00002820| 22 22 20 69 6e 74 65 72 | 6e 5d 20 36 5d 29 0a 28 |"" inter|n] 6]).(|
|00002830| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 72 65 61 |defalias| 'ad-rea|
|00002840| 64 2d 61 64 76 69 63 65 | 2d 73 70 65 63 69 66 69 |d-advice|-specifi|
|00002850| 63 61 74 69 6f 6e 20 23 | 5b 28 26 6f 70 74 69 6f |cation #|[(&optio|
|00002860| 6e 61 6c 20 70 72 6f 6d | 70 74 29 20 22 c0 09 21 |nal prom|pt) "..!|
|00002870| 1a c3 5c 6e 21 1c c5 5c | 6e 0c 5c 22 1e 06 5c 6e |..\n!..\|n.\"..\n|
|00002880| 0c 0e 06 45 2b 87 22 20 | 5b 61 64 2d 72 65 61 64 |...E+." |[ad-read|
|00002890| 2d 61 64 76 69 73 65 64 | 2d 66 75 6e 63 74 69 6f |-advised|-functio|
|000028a0| 6e 20 70 72 6f 6d 70 74 | 20 66 75 6e 63 74 69 6f |n prompt| functio|
|000028b0| 6e 20 61 64 2d 72 65 61 | 64 2d 61 64 76 69 63 65 |n ad-rea|d-advice|
|000028c0| 2d 63 6c 61 73 73 20 63 | 6c 61 73 73 20 61 64 2d |-class c|lass ad-|
|000028d0| 72 65 61 64 2d 61 64 76 | 69 63 65 2d 6e 61 6d 65 |read-adv|ice-name|
|000028e0| 20 6e 61 6d 65 5d 20 33 | 5d 29 0a 28 62 79 74 65 | name] 3|]).(byte|
|000028f0| 2d 63 6f 64 65 20 22 c0 | c1 21 ac 82 c2 11 c1 0b |-code ".|.!......|
|00002900| 42 13 c0 87 22 20 5b 62 | 6f 75 6e 64 70 20 61 64 |B..." [b|oundp ad|
|00002910| 2d 6c 61 73 74 2d 72 65 | 67 65 78 70 20 22 22 20 |-last-re|gexp "" |
|00002920| 63 75 72 72 65 6e 74 2d | 6c 6f 61 64 2d 6c 69 73 |current-|load-lis|
|00002930| 74 5d 20 32 29 0a 28 64 | 65 66 61 6c 69 61 73 20 |t] 2).(d|efalias |
|00002940| 27 61 64 2d 72 65 61 64 | 2d 72 65 67 65 78 70 20 |'ad-read|-regexp |
|00002950| 23 5b 28 26 6f 70 74 69 | 6f 6e 61 6c 20 70 72 6f |#[(&opti|onal pro|
|00002960| 6d 70 74 29 20 22 c0 09 | ae 81 c2 0b c4 6b ab 83 |mpt) "..|.....k..|
|00002970| c4 aa 84 c5 c6 0b 5c 22 | 50 21 89 1e 07 c4 6b ab |......\"|P!....k.|
|00002980| 83 0b aa 82 0e 07 89 13 | 29 87 22 20 5b 72 65 61 |........|)." [rea|
|00002990| 64 2d 66 72 6f 6d 2d 6d | 69 6e 69 62 75 66 66 65 |d-from-m|inibuffe|
|000029a0| 72 20 70 72 6f 6d 70 74 | 20 22 52 65 67 75 6c 61 |r prompt| "Regula|
|000029b0| 72 20 65 78 70 72 65 73 | 73 69 6f 6e 3a 20 22 20 |r expres|sion: " |
|000029c0| 61 64 2d 6c 61 73 74 2d | 72 65 67 65 78 70 20 22 |ad-last-|regexp "|
|000029d0| 22 20 66 6f 72 6d 61 74 | 20 22 28 64 65 66 61 75 |" format| "(defau|
|000029e0| 6c 74 20 5c 22 25 73 5c | 22 29 20 22 20 72 65 67 |lt \"%s\|") " reg|
|000029f0| 65 78 70 5d 20 36 5d 29 | 0a 28 64 65 66 61 6c 69 |exp] 6])|.(defali|
|00002a00| 61 73 20 27 61 64 2d 66 | 69 6e 64 2d 61 64 76 69 |as 'ad-f|ind-advi|
|00002a10| 63 65 20 27 28 6d 61 63 | 72 6f 20 2e 20 23 5b 28 |ce '(mac|ro . #[(|
|00002a20| 66 75 6e 63 74 69 6f 6e | 20 63 6c 61 73 73 20 6e |function| class n|
|00002a30| 61 6d 65 29 20 22 c0 09 | c2 0b 0c 45 45 87 22 20 |ame) "..|...EE." |
|00002a40| 5b 61 73 73 71 20 6e 61 | 6d 65 20 61 64 2d 67 65 |[assq na|me ad-ge|
|00002a50| 74 2d 61 64 76 69 63 65 | 2d 69 6e 66 6f 2d 66 69 |t-advice|-info-fi|
|00002a60| 65 6c 64 20 66 75 6e 63 | 74 69 6f 6e 20 63 6c 61 |eld func|tion cla|
|00002a70| 73 73 5d 20 35 5d 29 29 | 0a 28 64 65 66 61 6c 69 |ss] 5]))|.(defali|
|00002a80| 61 73 20 27 61 64 2d 61 | 64 76 69 63 65 2d 70 6f |as 'ad-a|dvice-po|
|00002a90| 73 69 74 69 6f 6e 20 23 | 5b 28 66 75 6e 63 74 69 |sition #|[(functi|
|00002aa0| 6f 6e 20 63 6c 61 73 73 | 20 6e 61 6d 65 29 20 22 |on class| name) "|
|00002ab0| 08 09 5c 6e c3 4e b7 41 | b7 1c 09 5c 6e c3 4e b7 |..\n.N.A|...\n.N.|
|00002ac0| 41 1d 0c ad 87 0d 47 0c | 0d 73 47 5a 2a 87 22 20 |A.....G.|.sGZ*." |
|00002ad0| 5b 6e 61 6d 65 20 63 6c | 61 73 73 20 66 75 6e 63 |[name cl|ass func|
|00002ae0| 74 69 6f 6e 20 61 64 2d | 61 64 76 69 63 65 2d 69 |tion ad-|advice-i|
|00002af0| 6e 66 6f 20 66 6f 75 6e | 64 2d 61 64 76 69 63 65 |nfo foun|d-advice|
|00002b00| 20 61 64 76 69 63 65 73 | 5d 20 34 5d 29 0a 23 40 | advices|] 4]).#@|
|00002b10| 32 30 31 20 46 69 6e 64 | 73 20 74 68 65 20 66 69 |201 Find|s the fi|
|00002b20| 72 73 74 20 6f 66 20 46 | 55 4e 43 54 49 4f 4e 27 |rst of F|UNCTION'|
|00002b30| 73 20 61 64 76 69 63 65 | 73 20 69 6e 20 43 4c 41 |s advice|s in CLA|
|00002b40| 53 53 20 6d 61 74 63 68 | 69 6e 67 20 4e 41 4d 45 |SS match|ing NAME|
|00002b50| 2e 0a 4e 41 4d 45 20 63 | 61 6e 20 62 65 20 61 20 |..NAME c|an be a |
|00002b60| 73 79 6d 62 6f 6c 20 6f | 72 20 61 20 72 65 67 75 |symbol o|r a regu|
|00002b70| 6c 61 72 20 65 78 70 72 | 65 73 73 69 6f 6e 20 6d |lar expr|ession m|
|00002b80| 61 74 63 68 69 6e 67 20 | 70 61 72 74 20 6f 66 20 |atching |part of |
|00002b90| 61 6e 20 61 64 76 69 63 | 65 20 6e 61 6d 65 2e 0a |an advic|e name..|
|00002ba0| 49 66 20 43 4c 41 53 53 | 20 69 73 20 60 61 6e 79 |If CLASS| is `any|
|00002bb0| 27 20 61 6c 6c 20 6c 65 | 67 61 6c 20 61 64 76 69 |' all le|gal advi|
|00002bc0| 63 65 20 63 6c 61 73 73 | 65 73 20 77 69 6c 6c 20 |ce class|es will |
|00002bd0| 62 65 20 63 68 65 63 6b | 65 64 2e 1f 0a 28 64 65 |be check|ed...(de|
|00002be0| 66 61 6c 69 61 73 20 27 | 61 64 2d 66 69 6e 64 2d |falias '|ad-find-|
|00002bf0| 73 6f 6d 65 2d 61 64 76 | 69 63 65 20 23 5b 28 66 |some-adv|ice #[(f|
|00002c00| 75 6e 63 74 69 6f 6e 20 | 63 6c 61 73 73 20 6e 61 |unction |class na|
|00002c10| 6d 65 29 20 22 08 c1 4e | ad 86 c2 1b c4 c5 8d 29 |me) "..N|.......)|
|00002c20| 87 22 20 5b 66 75 6e 63 | 74 69 6f 6e 20 61 64 2d |." [func|tion ad-|
|00002c30| 61 64 76 69 63 65 2d 69 | 6e 66 6f 20 6e 69 6c 20 |advice-i|nfo nil |
|00002c40| 66 6f 75 6e 64 2d 61 64 | 76 69 63 65 20 61 64 2d |found-ad|vice ad-|
|00002c50| 64 4f 2d 65 58 69 54 20 | 28 62 79 74 65 2d 63 6f |dO-eXiT |(byte-co|
|00002c60| 64 65 20 22 08 c1 1a 89 | 1b ab a2 0b 40 12 0c c5 |de "....|....@...|
|00002c70| 61 ac 85 5c 6e 0c 61 ab | 85 c6 c7 8d 16 08 0e 08 |a..\n.a.|........|
|00002c80| ab 86 c9 c6 0e 08 5c 22 | 88 0b 41 89 13 ac 5e 2a |......\"|..A...^*|
|00002c90| c1 87 22 20 5b 61 64 2d | 61 64 76 69 63 65 2d 63 |.." [ad-|advice-c|
|00002ca0| 6c 61 73 73 65 73 20 6e | 69 6c 20 61 64 76 69 63 |lasses n|il advic|
|00002cb0| 65 2d 63 6c 61 73 73 20 | 61 64 2d 64 4f 2d 76 41 |e-class |ad-dO-vA|
|00002cc0| 72 20 63 6c 61 73 73 20 | 61 6e 79 20 61 64 2d 64 |r class |any ad-d|
|00002cd0| 4f 2d 65 58 69 54 20 28 | 62 79 74 65 2d 63 6f 64 |O-eXiT (|byte-cod|
|00002ce0| 65 20 22 08 09 c2 4e b7 | 41 c3 1c 89 1d ab a4 0d |e "...N.|A.......|
|00002cf0| 40 14 0e 06 3b ab 8a c7 | 0e 06 c8 0c 40 21 5c 22 |@...;...|....@!\"|
|00002d00| ac 87 0e 06 0c 40 61 ab | 85 c9 ca 0c 5c 22 88 0d |.....@a.|....\"..|
|00002d10| 41 89 15 ac 5c 5c 2a c3 | 87 22 20 5b 61 64 76 69 |A...\\*.|." [advi|
|00002d20| 63 65 2d 63 6c 61 73 73 | 20 66 75 6e 63 74 69 6f |ce-class| functio|
|00002d30| 6e 20 61 64 2d 61 64 76 | 69 63 65 2d 69 6e 66 6f |n ad-adv|ice-info|
|00002d40| 20 6e 69 6c 20 61 64 76 | 69 63 65 20 61 64 2d 64 | nil adv|ice ad-d|
|00002d50| 4f 2d 76 41 72 20 6e 61 | 6d 65 20 73 74 72 69 6e |O-vAr na|me strin|
|00002d60| 67 2d 6d 61 74 63 68 20 | 73 79 6d 62 6f 6c 2d 6e |g-match |symbol-n|
|00002d70| 61 6d 65 20 74 68 72 6f | 77 20 61 64 2d 64 4f 2d |ame thro|w ad-dO-|
|00002d80| 65 58 69 54 5d 20 35 29 | 20 66 6f 75 6e 64 2d 61 |eXiT] 5)| found-a|
|00002d90| 64 76 69 63 65 20 74 68 | 72 6f 77 5d 20 34 29 5d |dvice th|row] 4)]|
|00002da0| 20 32 20 28 23 24 20 2e | 20 31 31 30 32 38 29 5d | 2 (#$ .| 11028)]|
|00002db0| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00002dc0| 65 6e 61 62 6c 65 2d 61 | 64 76 69 63 65 2d 69 6e |enable-a|dvice-in|
|00002dd0| 74 65 72 6e 61 6c 20 23 | 5b 28 66 75 6e 63 74 69 |ternal #|[(functi|
|00002de0| 6f 6e 20 63 6c 61 73 73 | 20 6e 61 6d 65 20 66 6c |on class| name fl|
|00002df0| 61 67 29 20 22 08 c1 4e | ad e7 c2 1b 0c c5 1e 06 |ag) "..N|........|
|00002e00| 89 1e 07 ab d9 0e 07 40 | 16 06 0e 08 c9 61 ac 87 |.......@|.....a..|
|00002e10| 0e 06 0e 08 61 ab bf 0e | 06 08 c1 4e b7 41 c5 1e |....a...|...N.A..|
|00002e20| 5c 6e 89 1e 07 ab af 0e | 07 40 16 5c 6e 0e 0b 3b |\n......|.@.\n..;|
|00002e30| ab 8b cc 0e 0b cd 0e 5c | 6e 40 21 5c 22 ac 88 0e |.......\|n@!\"...|
|00002e40| 0b 0e 5c 6e 40 61 ab 8a | 0b 54 13 ce 0e 5c 6e 0e |..\n@a..|.T...\n.|
|00002e50| 0f 5c 22 88 0e 07 41 89 | 16 07 ac 51 2a 0e 07 41 |.\"...A.|...Q*..A|
|00002e60| 89 16 07 ac 27 2a 0b 29 | 87 22 20 5b 66 75 6e 63 |....'*.)|." [func|
|00002e70| 74 69 6f 6e 20 61 64 2d | 61 64 76 69 63 65 2d 69 |tion ad-|advice-i|
|00002e80| 6e 66 6f 20 30 20 6d 61 | 74 63 68 65 64 2d 61 64 |nfo 0 ma|tched-ad|
|00002e90| 76 69 63 65 73 20 61 64 | 2d 61 64 76 69 63 65 2d |vices ad|-advice-|
|00002ea0| 63 6c 61 73 73 65 73 20 | 6e 69 6c 20 61 64 76 69 |classes |nil advi|
|00002eb0| 63 65 2d 63 6c 61 73 73 | 20 61 64 2d 64 4f 2d 76 |ce-class| ad-dO-v|
|00002ec0| 41 72 20 63 6c 61 73 73 | 20 61 6e 79 20 61 64 76 |Ar class| any adv|
|00002ed0| 69 63 65 20 6e 61 6d 65 | 20 73 74 72 69 6e 67 2d |ice name| string-|
|00002ee0| 6d 61 74 63 68 20 73 79 | 6d 62 6f 6c 2d 6e 61 6d |match sy|mbol-nam|
|00002ef0| 65 20 61 64 2d 61 64 76 | 69 63 65 2d 73 65 74 2d |e ad-adv|ice-set-|
|00002f00| 65 6e 61 62 6c 65 64 20 | 66 6c 61 67 5d 20 35 5d |enabled |flag] 5]|
|00002f10| 29 0a 23 40 35 33 20 45 | 6e 61 62 6c 65 73 20 74 |).#@53 E|nables t|
|00002f20| 68 65 20 61 64 76 69 63 | 65 20 6f 66 20 46 55 4e |he advic|e of FUN|
|00002f30| 43 54 49 4f 4e 20 77 69 | 74 68 20 43 4c 41 53 53 |CTION wi|th CLASS|
|00002f40| 20 61 6e 64 20 4e 41 4d | 45 2e 1f 0a 28 64 65 66 | and NAM|E...(def|
|00002f50| 61 6c 69 61 73 20 27 61 | 64 2d 65 6e 61 62 6c 65 |alias 'a|d-enable|
|00002f60| 2d 61 64 76 69 63 65 20 | 23 5b 28 66 75 6e 63 74 |-advice |#[(funct|
|00002f70| 69 6f 6e 20 63 6c 61 73 | 73 20 6e 61 6d 65 29 20 |ion clas|s name) |
|00002f80| 22 08 c1 4e ab 91 c2 08 | 0b 0c c5 24 c6 61 ad 8b |"..N....|...$.a..|
|00002f90| c7 c8 08 0b 0c 24 87 c7 | c9 08 5c 22 87 22 20 5b |.....$..|..\"." [|
|00002fa0| 66 75 6e 63 74 69 6f 6e | 20 61 64 2d 61 64 76 69 |function| ad-advi|
|00002fb0| 63 65 2d 69 6e 66 6f 20 | 61 64 2d 65 6e 61 62 6c |ce-info |ad-enabl|
|00002fc0| 65 2d 61 64 76 69 63 65 | 2d 69 6e 74 65 72 6e 61 |e-advice|-interna|
|00002fd0| 6c 20 63 6c 61 73 73 20 | 6e 61 6d 65 20 74 20 30 |l class |name t 0|
|00002fe0| 20 65 72 72 6f 72 20 22 | 61 64 2d 65 6e 61 62 6c | error "|ad-enabl|
|00002ff0| 65 2d 61 64 76 69 63 65 | 3a 20 60 25 73 27 20 68 |e-advice|: `%s' h|
|00003000| 61 73 20 6e 6f 20 25 73 | 20 61 64 76 69 63 65 20 |as no %s| advice |
|00003010| 6d 61 74 63 68 69 6e 67 | 20 60 25 73 27 22 20 22 |matching| `%s'" "|
|00003020| 61 64 2d 65 6e 61 62 6c | 65 2d 61 64 76 69 63 65 |ad-enabl|e-advice|
|00003030| 3a 20 60 25 73 27 20 69 | 73 20 6e 6f 74 20 61 64 |: `%s' i|s not ad|
|00003040| 76 69 73 65 64 22 5d 20 | 35 20 28 23 24 20 2e 20 |vised"] |5 (#$ . |
|00003050| 31 32 30 35 35 29 20 28 | 61 64 2d 72 65 61 64 2d |12055) (|ad-read-|
|00003060| 61 64 76 69 63 65 2d 73 | 70 65 63 69 66 69 63 61 |advice-s|pecifica|
|00003070| 74 69 6f 6e 20 22 45 6e | 61 62 6c 65 20 61 64 76 |tion "En|able adv|
|00003080| 69 63 65 20 6f 66 3a 20 | 22 29 5d 29 0a 23 40 35 |ice of: |")]).#@5|
|00003090| 34 20 44 69 73 61 62 6c | 65 73 20 74 68 65 20 61 |4 Disabl|es the a|
|000030a0| 64 76 69 63 65 20 6f 66 | 20 46 55 4e 43 54 49 4f |dvice of| FUNCTIO|
|000030b0| 4e 20 77 69 74 68 20 43 | 4c 41 53 53 20 61 6e 64 |N with C|LASS and|
|000030c0| 20 4e 41 4d 45 2e 1f 0a | 28 64 65 66 61 6c 69 61 | NAME...|(defalia|
|000030d0| 73 20 27 61 64 2d 64 69 | 73 61 62 6c 65 2d 61 64 |s 'ad-di|sable-ad|
|000030e0| 76 69 63 65 20 23 5b 28 | 66 75 6e 63 74 69 6f 6e |vice #[(|function|
|000030f0| 20 63 6c 61 73 73 20 6e | 61 6d 65 29 20 22 08 c1 | class n|ame) "..|
|00003100| 4e ab 91 c2 08 0b 0c c5 | 24 c6 61 ad 8b c7 c8 08 |N.......|$.a.....|
|00003110| 0b 0c 24 87 c7 c9 08 5c | 22 87 22 20 5b 66 75 6e |..$....\|"." [fun|
|00003120| 63 74 69 6f 6e 20 61 64 | 2d 61 64 76 69 63 65 2d |ction ad|-advice-|
|00003130| 69 6e 66 6f 20 61 64 2d | 65 6e 61 62 6c 65 2d 61 |info ad-|enable-a|
|00003140| 64 76 69 63 65 2d 69 6e | 74 65 72 6e 61 6c 20 63 |dvice-in|ternal c|
|00003150| 6c 61 73 73 20 6e 61 6d | 65 20 6e 69 6c 20 30 20 |lass nam|e nil 0 |
|00003160| 65 72 72 6f 72 20 22 61 | 64 2d 64 69 73 61 62 6c |error "a|d-disabl|
|00003170| 65 2d 61 64 76 69 63 65 | 3a 20 60 25 73 27 20 68 |e-advice|: `%s' h|
|00003180| 61 73 20 6e 6f 20 25 73 | 20 61 64 76 69 63 65 20 |as no %s| advice |
|00003190| 6d 61 74 63 68 69 6e 67 | 20 60 25 73 27 22 20 22 |matching| `%s'" "|
|000031a0| 61 64 2d 64 69 73 61 62 | 6c 65 2d 61 64 76 69 63 |ad-disab|le-advic|
|000031b0| 65 3a 20 60 25 73 27 20 | 69 73 20 6e 6f 74 20 61 |e: `%s' |is not a|
|000031c0| 64 76 69 73 65 64 22 5d | 20 35 20 28 23 24 20 2e |dvised"]| 5 (#$ .|
|000031d0| 20 31 32 34 33 34 29 20 | 28 61 64 2d 72 65 61 64 | 12434) |(ad-read|
|000031e0| 2d 61 64 76 69 63 65 2d | 73 70 65 63 69 66 69 63 |-advice-|specific|
|000031f0| 61 74 69 6f 6e 20 22 44 | 69 73 61 62 6c 65 20 61 |ation "D|isable a|
|00003200| 64 76 69 63 65 20 6f 66 | 3a 20 22 29 5d 29 0a 28 |dvice of|: ")]).(|
|00003210| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 65 6e 61 |defalias| 'ad-ena|
|00003220| 62 6c 65 2d 72 65 67 65 | 78 70 2d 69 6e 74 65 72 |ble-rege|xp-inter|
|00003230| 6e 61 6c 20 23 5b 28 72 | 65 67 65 78 70 20 63 6c |nal #[(r|egexp cl|
|00003240| 61 73 73 20 66 6c 61 67 | 29 20 22 c0 19 5c 6e c3 |ass flag|) "..\n.|
|00003250| 1c 89 1d ab 9d 0d 40 14 | c6 0c 40 21 14 09 c7 0c |......@.|..@!....|
|00003260| 0e 08 0e 09 0e 5c 6e 24 | ae 81 c0 5c 5c 11 0d 41 |.....\n$|...\\..A|
|00003270| 89 15 ac 63 2a 09 29 87 | 22 20 5b 30 20 6d 61 74 |...c*.).|" [0 mat|
|00003280| 63 68 65 64 2d 61 64 76 | 69 63 65 73 20 61 64 2d |ched-adv|ices ad-|
|00003290| 61 64 76 69 73 65 64 2d | 66 75 6e 63 74 69 6f 6e |advised-|function|
|000032a0| 73 20 6e 69 6c 20 61 64 | 76 69 73 65 64 2d 66 75 |s nil ad|vised-fu|
|000032b0| 6e 63 74 69 6f 6e 20 61 | 64 2d 64 4f 2d 76 41 72 |nction a|d-dO-vAr|
|000032c0| 20 69 6e 74 65 72 6e 20 | 61 64 2d 65 6e 61 62 6c | intern |ad-enabl|
|000032d0| 65 2d 61 64 76 69 63 65 | 2d 69 6e 74 65 72 6e 61 |e-advice|-interna|
|000032e0| 6c 20 63 6c 61 73 73 20 | 72 65 67 65 78 70 20 66 |l class |regexp f|
|000032f0| 6c 61 67 5d 20 37 5d 29 | 0a 23 40 31 31 37 20 45 |lag] 7])|.#@117 E|
|00003300| 6e 61 62 6c 65 73 20 61 | 6c 6c 20 61 64 76 69 63 |nables a|ll advic|
|00003310| 65 73 20 77 69 74 68 20 | 6e 61 6d 65 73 20 74 68 |es with |names th|
|00003320| 61 74 20 63 6f 6e 74 61 | 69 6e 20 61 20 6d 61 74 |at conta|in a mat|
|00003330| 63 68 20 66 6f 72 20 52 | 45 47 45 58 50 2e 0a 41 |ch for R|EGEXP..A|
|00003340| 6c 6c 20 63 75 72 72 65 | 6e 74 6c 79 20 61 64 76 |ll curre|ntly adv|
|00003350| 69 73 65 64 20 66 75 6e | 63 74 69 6f 6e 73 20 77 |ised fun|ctions w|
|00003360| 69 6c 6c 20 62 65 20 63 | 6f 6e 73 69 64 65 72 65 |ill be c|onsidere|
|00003370| 64 2e 1f 0a 28 64 65 66 | 61 6c 69 61 73 20 27 61 |d...(def|alias 'a|
|00003380| 64 2d 65 6e 61 62 6c 65 | 2d 72 65 67 65 78 70 20 |d-enable|-regexp |
|00003390| 23 5b 28 72 65 67 65 78 | 70 29 20 22 c0 09 c2 c3 |#[(regex|p) "....|
|000033a0| 23 1c 74 ab 85 c5 c6 0c | 5c 22 88 0c 29 87 22 20 |#.t.....|\"..)." |
|000033b0| 5b 61 64 2d 65 6e 61 62 | 6c 65 2d 72 65 67 65 78 |[ad-enab|le-regex|
|000033c0| 70 2d 69 6e 74 65 72 6e | 61 6c 20 72 65 67 65 78 |p-intern|al regex|
|000033d0| 70 20 61 6e 79 20 74 20 | 6d 61 74 63 68 65 64 2d |p any t |matched-|
|000033e0| 61 64 76 69 63 65 73 20 | 6d 65 73 73 61 67 65 20 |advices |message |
|000033f0| 22 25 64 20 6d 61 74 63 | 68 69 6e 67 20 61 64 76 |"%d matc|hing adv|
|00003400| 69 63 65 73 20 65 6e 61 | 62 6c 65 64 22 5d 20 34 |ices ena|bled"] 4|
|00003410| 20 28 23 24 20 2e 20 31 | 33 30 35 35 29 20 28 6c | (#$ . 1|3055) (l|
|00003420| 69 73 74 20 28 61 64 2d | 72 65 61 64 2d 72 65 67 |ist (ad-|read-reg|
|00003430| 65 78 70 20 22 45 6e 61 | 62 6c 65 20 61 64 76 69 |exp "Ena|ble advi|
|00003440| 63 65 73 20 76 69 61 20 | 72 65 67 65 78 70 3a 20 |ces via |regexp: |
|00003450| 22 29 29 5d 29 0a 23 40 | 31 31 38 20 44 69 73 61 |"))]).#@|118 Disa|
|00003460| 62 6c 65 73 20 61 6c 6c | 20 61 64 76 69 63 65 73 |bles all| advices|
|00003470| 20 77 69 74 68 20 6e 61 | 6d 65 73 20 74 68 61 74 | with na|mes that|
|00003480| 20 63 6f 6e 74 61 69 6e | 20 61 20 6d 61 74 63 68 | contain| a match|
|00003490| 20 66 6f 72 20 52 45 47 | 45 58 50 2e 0a 41 6c 6c | for REG|EXP..All|
|000034a0| 20 63 75 72 72 65 6e 74 | 6c 79 20 61 64 76 69 73 | current|ly advis|
|000034b0| 65 64 20 66 75 6e 63 74 | 69 6f 6e 73 20 77 69 6c |ed funct|ions wil|
|000034c0| 6c 20 62 65 20 63 6f 6e | 73 69 64 65 72 65 64 2e |l be con|sidered.|
|000034d0| 1f 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |..(defal|ias 'ad-|
|000034e0| 64 69 73 61 62 6c 65 2d | 72 65 67 65 78 70 20 23 |disable-|regexp #|
|000034f0| 5b 28 72 65 67 65 78 70 | 29 20 22 c0 09 c2 c3 23 |[(regexp|) "....#|
|00003500| 1c 74 ab 85 c5 c6 0c 5c | 22 88 0c 29 87 22 20 5b |.t.....\|"..)." [|
|00003510| 61 64 2d 65 6e 61 62 6c | 65 2d 72 65 67 65 78 70 |ad-enabl|e-regexp|
|00003520| 2d 69 6e 74 65 72 6e 61 | 6c 20 72 65 67 65 78 70 |-interna|l regexp|
|00003530| 20 61 6e 79 20 6e 69 6c | 20 6d 61 74 63 68 65 64 | any nil| matched|
|00003540| 2d 61 64 76 69 63 65 73 | 20 6d 65 73 73 61 67 65 |-advices| message|
|00003550| 20 22 25 64 20 6d 61 74 | 63 68 69 6e 67 20 61 64 | "%d mat|ching ad|
|00003560| 76 69 63 65 73 20 64 69 | 73 61 62 6c 65 64 22 5d |vices di|sabled"]|
|00003570| 20 34 20 28 23 24 20 2e | 20 31 33 34 30 34 29 20 | 4 (#$ .| 13404) |
|00003580| 28 6c 69 73 74 20 28 61 | 64 2d 72 65 61 64 2d 72 |(list (a|d-read-r|
|00003590| 65 67 65 78 70 20 22 44 | 69 73 61 62 6c 65 20 61 |egexp "D|isable a|
|000035a0| 64 76 69 63 65 73 20 76 | 69 61 20 72 65 67 65 78 |dvices v|ia regex|
|000035b0| 70 3a 20 22 29 29 5d 29 | 0a 23 40 31 35 31 20 52 |p: "))])|.#@151 R|
|000035c0| 65 6d 6f 76 65 73 20 46 | 55 4e 43 54 49 4f 4e 27 |emoves F|UNCTION'|
|000035d0| 73 20 61 64 76 69 63 65 | 20 77 69 74 68 20 4e 41 |s advice| with NA|
|000035e0| 4d 45 20 66 72 6f 6d 20 | 69 74 73 20 61 64 76 69 |ME from |its advi|
|000035f0| 63 65 73 20 69 6e 20 43 | 4c 41 53 53 2e 0a 49 66 |ces in C|LASS..If|
|00003600| 20 73 75 63 68 20 61 6e | 20 61 64 76 69 63 65 20 | such an| advice |
|00003610| 77 61 73 20 66 6f 75 6e | 64 20 69 74 20 77 69 6c |was foun|d it wil|
|00003620| 6c 20 62 65 20 72 65 6d | 6f 76 65 64 20 66 72 6f |l be rem|oved fro|
|00003630| 6d 20 74 68 65 20 6c 69 | 73 74 20 6f 66 20 61 64 |m the li|st of ad|
|00003640| 76 69 63 65 73 0a 69 6e | 20 74 68 61 74 20 43 4c |vices.in| that CL|
|00003650| 41 53 53 2e 1f 0a 28 64 | 65 66 61 6c 69 61 73 20 |ASS...(d|efalias |
|00003660| 27 61 64 2d 72 65 6d 6f | 76 65 2d 61 64 76 69 63 |'ad-remo|ve-advic|
|00003670| 65 20 23 5b 28 66 75 6e | 63 74 69 6f 6e 20 63 6c |e #[(fun|ction cl|
|00003680| 61 73 73 20 6e 61 6d 65 | 29 20 22 08 c1 4e ab a3 |ass name|) "..N..|
|00003690| 5c 6e 0b 08 c1 4e b7 41 | b7 89 1c ab 8f c5 08 0b |\n...N.A|........|
|000036a0| c6 0c 0b 08 c1 4e b7 41 | 5c 22 23 aa 86 c7 c8 08 |.....N.A|\"#.....|
|000036b0| 0b 5c 6e 24 29 87 c7 c9 | 08 5c 22 87 22 20 5b 66 |.\n$)...|.\"." [f|
|000036c0| 75 6e 63 74 69 6f 6e 20 | 61 64 2d 61 64 76 69 63 |unction |ad-advic|
|000036d0| 65 2d 69 6e 66 6f 20 6e | 61 6d 65 20 63 6c 61 73 |e-info n|ame clas|
|000036e0| 73 20 61 64 76 69 63 65 | 2d 74 6f 2d 72 65 6d 6f |s advice|-to-remo|
|000036f0| 76 65 20 61 64 2d 73 65 | 74 2d 61 64 76 69 63 65 |ve ad-se|t-advice|
|00003700| 2d 69 6e 66 6f 2d 66 69 | 65 6c 64 20 64 65 6c 71 |-info-fi|eld delq|
|00003710| 20 65 72 72 6f 72 20 22 | 61 64 2d 72 65 6d 6f 76 | error "|ad-remov|
|00003720| 65 2d 61 64 76 69 63 65 | 3a 20 60 25 73 27 20 68 |e-advice|: `%s' h|
|00003730| 61 73 20 6e 6f 20 25 73 | 20 61 64 76 69 63 65 20 |as no %s| advice |
|00003740| 60 25 73 27 22 20 22 61 | 64 2d 72 65 6d 6f 76 65 |`%s'" "a|d-remove|
|00003750| 2d 61 64 76 69 63 65 3a | 20 60 25 73 27 20 69 73 |-advice:| `%s' is|
|00003760| 20 6e 6f 74 20 61 64 76 | 69 73 65 64 22 5d 20 39 | not adv|ised"] 9|
|00003770| 20 28 23 24 20 2e 20 31 | 33 37 35 39 29 20 28 61 | (#$ . 1|3759) (a|
|00003780| 64 2d 72 65 61 64 2d 61 | 64 76 69 63 65 2d 73 70 |d-read-a|dvice-sp|
|00003790| 65 63 69 66 69 63 61 74 | 69 6f 6e 20 22 52 65 6d |ecificat|ion "Rem|
|000037a0| 6f 76 65 20 61 64 76 69 | 63 65 20 6f 66 3a 20 22 |ove advi|ce of: "|
|000037b0| 29 5d 29 0a 23 40 37 30 | 31 20 41 64 64 73 20 61 |)]).#@70|1 Adds a|
|000037c0| 20 70 69 65 63 65 20 6f | 66 20 41 44 56 49 43 45 | piece o|f ADVICE|
|000037d0| 20 74 6f 20 46 55 4e 43 | 54 49 4f 4e 27 73 20 6c | to FUNC|TION's l|
|000037e0| 69 73 74 20 6f 66 20 61 | 64 76 69 63 65 73 20 69 |ist of a|dvices i|
|000037f0| 6e 20 43 4c 41 53 53 2e | 0a 49 66 20 46 55 4e 43 |n CLASS.|.If FUNC|
|00003800| 54 49 4f 4e 20 61 6c 72 | 65 61 64 79 20 68 61 73 |TION alr|eady has|
|00003810| 20 6f 6e 65 20 6f 72 20 | 6d 6f 72 65 20 70 69 65 | one or |more pie|
|00003820| 63 65 73 20 6f 66 20 61 | 64 76 69 63 65 20 6f 66 |ces of a|dvice of|
|00003830| 20 74 68 65 20 73 70 65 | 63 69 66 69 65 64 0a 43 | the spe|cified.C|
|00003840| 4c 41 53 53 20 74 68 65 | 6e 20 50 4f 53 49 54 49 |LASS the|n POSITI|
|00003850| 4f 4e 20 64 65 74 65 72 | 6d 69 6e 65 73 20 77 68 |ON deter|mines wh|
|00003860| 65 72 65 20 74 68 65 20 | 6e 65 77 20 70 69 65 63 |ere the |new piec|
|00003870| 65 20 77 69 6c 6c 20 67 | 6f 2e 20 20 54 68 65 20 |e will g|o. The |
|00003880| 76 61 6c 75 65 0a 6f 66 | 20 50 4f 53 49 54 49 4f |value.of| POSITIO|
|00003890| 4e 20 63 61 6e 20 65 69 | 74 68 65 72 20 62 65 20 |N can ei|ther be |
|000038a0| 60 66 69 72 73 74 27 2c | 20 60 6c 61 73 74 27 20 |`first',| `last' |
|000038b0| 6f 72 20 61 20 6e 75 6d | 62 65 72 20 77 68 65 72 |or a num|ber wher|
|000038c0| 65 20 30 20 63 6f 72 72 | 65 73 70 6f 6e 64 73 0a |e 0 corr|esponds.|
|000038d0| 74 6f 20 60 66 69 72 73 | 74 27 2e 20 20 4e 75 6d |to `firs|t'. Num|
|000038e0| 62 65 72 73 20 6f 75 74 | 73 69 64 65 20 74 68 65 |bers out|side the|
|000038f0| 20 72 61 6e 67 65 20 77 | 69 6c 6c 20 62 65 20 6d | range w|ill be m|
|00003900| 61 70 70 65 64 20 74 6f | 20 74 68 65 20 63 6c 6f |apped to| the clo|
|00003910| 73 65 73 74 0a 65 78 74 | 72 65 6d 65 20 70 6f 73 |sest.ext|reme pos|
|00003920| 69 74 69 6f 6e 2e 20 20 | 49 66 20 74 68 65 72 65 |ition. |If there|
|00003930| 20 77 61 73 20 61 6c 72 | 65 61 64 79 20 61 20 70 | was alr|eady a p|
|00003940| 69 65 63 65 20 6f 66 20 | 41 44 56 49 43 45 20 77 |iece of |ADVICE w|
|00003950| 69 74 68 20 74 68 65 20 | 73 61 6d 65 0a 6e 61 6d |ith the |same.nam|
|00003960| 65 2c 20 74 68 65 6e 20 | 74 68 65 20 70 6f 73 69 |e, then |the posi|
|00003970| 74 69 6f 6e 20 61 72 67 | 75 6d 65 6e 74 20 77 69 |tion arg|ument wi|
|00003980| 6c 6c 20 62 65 20 69 67 | 6e 6f 72 65 64 20 61 6e |ll be ig|nored an|
|00003990| 64 20 74 68 65 20 6f 6c | 64 20 61 64 76 69 63 65 |d the ol|d advice|
|000039a0| 0a 77 69 6c 6c 20 62 65 | 20 6f 76 65 72 77 72 69 |.will be| overwri|
|000039b0| 74 74 65 6e 20 77 69 74 | 68 20 74 68 65 20 6e 65 |tten wit|h the ne|
|000039c0| 77 20 6f 6e 65 2e 0a 20 | 20 20 20 49 66 20 74 68 |w one.. | If th|
|000039d0| 65 20 46 55 4e 43 54 49 | 4f 4e 20 77 61 73 20 6e |e FUNCTI|ON was n|
|000039e0| 6f 74 20 61 64 76 69 73 | 65 64 20 61 6c 72 65 61 |ot advis|ed alrea|
|000039f0| 64 79 2c 20 74 68 65 6e | 20 69 74 73 20 61 64 76 |dy, then| its adv|
|00003a00| 69 63 65 20 69 6e 66 6f | 20 77 69 6c 6c 20 62 65 |ice info| will be|
|00003a10| 20 0a 69 6e 69 74 69 61 | 6c 69 7a 65 64 2e 20 20 | .initia|lized. |
|00003a20| 52 65 64 65 66 69 6e 69 | 6e 67 20 61 20 70 69 65 |Redefini|ng a pie|
|00003a30| 63 65 20 6f 66 20 61 64 | 76 69 63 65 20 77 68 6f |ce of ad|vice who|
|00003a40| 73 65 20 6e 61 6d 65 20 | 69 73 20 70 61 72 74 20 |se name |is part |
|00003a50| 6f 66 20 74 68 65 20 63 | 61 63 68 65 2d 69 64 0a |of the c|ache-id.|
|00003a60| 77 69 6c 6c 20 63 6c 65 | 61 72 20 74 68 65 20 63 |will cle|ar the c|
|00003a70| 61 63 68 65 2e 1f 0a 28 | 64 65 66 61 6c 69 61 73 |ache...(|defalias|
|00003a80| 20 27 61 64 2d 61 64 64 | 2d 61 64 76 69 63 65 20 | 'ad-add|-advice |
|00003a90| 23 5b 28 66 75 6e 63 74 | 69 6f 6e 20 61 64 76 69 |#[(funct|ion advi|
|00003aa0| 63 65 20 63 6c 61 73 73 | 20 70 6f 73 69 74 69 6f |ce class| positio|
|00003ab0| 6e 29 20 22 08 c1 4e ac | 8c c2 08 21 88 c3 08 c4 |n) "..N.|...!....|
|00003ac0| c5 08 21 23 88 c6 08 0e | 07 0e 08 40 23 1e 09 0e |..!#....|...@#...|
|00003ad0| 07 08 c1 4e b7 41 1e 5c | 6e 0e 09 ae a4 0e 0b cc |...N.A.\|n.......|
|00003ae0| 61 ab 83 cd aa 9b 0e 0b | ce 61 ab 85 0e 5c 6e 47 |a.......|.a...\nG|
|00003af0| aa 90 0e 0b a7 ab 8a cd | 0e 0b 0e 5c 6e 47 5e 5d |........|...\nG^]|
|00003b00| aa 81 cd 1e 0b 0e 08 40 | cf 08 0e 07 5c 22 73 ab |.......@|....\"s.|
|00003b10| 84 d0 08 21 88 0e 09 ab | 8a 0e 0b 0e 5c 6e 9b 0e |...!....|....\n..|
|00003b20| 08 a0 aa a1 0e 0b cd 55 | ab 8c c3 08 0e 07 0e 08 |.......U|........|
|00003b30| 0e 5c 6e 42 23 aa 8f 0e | 0b 53 0e 5c 6e 9b 0e 08 |.\nB#...|.S.\n...|
|00003b40| 0e 0b 0e 5c 6e 9b 42 a1 | 2b 87 22 20 5b 66 75 6e |...\n.B.|+." [fun|
|00003b50| 63 74 69 6f 6e 20 61 64 | 2d 61 64 76 69 63 65 2d |ction ad|-advice-|
|00003b60| 69 6e 66 6f 20 61 64 2d | 69 6e 69 74 69 61 6c 69 |info ad-|initiali|
|00003b70| 7a 65 2d 61 64 76 69 63 | 65 2d 69 6e 66 6f 20 61 |ze-advic|e-info a|
|00003b80| 64 2d 73 65 74 2d 61 64 | 76 69 63 65 2d 69 6e 66 |d-set-ad|vice-inf|
|00003b90| 6f 2d 66 69 65 6c 64 20 | 6f 72 69 67 6e 61 6d 65 |o-field |origname|
|00003ba0| 20 61 64 2d 6d 61 6b 65 | 2d 6f 72 69 67 6e 61 6d | ad-make|-orignam|
|00003bb0| 65 20 61 64 2d 61 64 76 | 69 63 65 2d 70 6f 73 69 |e ad-adv|ice-posi|
|00003bc0| 74 69 6f 6e 20 63 6c 61 | 73 73 20 61 64 76 69 63 |tion cla|ss advic|
|00003bd0| 65 20 70 72 65 76 69 6f | 75 73 2d 70 6f 73 69 74 |e previo|us-posit|
|00003be0| 69 6f 6e 20 61 64 76 69 | 63 65 73 20 70 6f 73 69 |ion advi|ces posi|
|00003bf0| 74 69 6f 6e 20 66 69 72 | 73 74 20 30 20 6c 61 73 |tion fir|st 0 las|
|00003c00| 74 20 61 64 2d 67 65 74 | 2d 63 61 63 68 65 2d 63 |t ad-get|-cache-c|
|00003c10| 6c 61 73 73 2d 69 64 20 | 61 64 2d 63 6c 65 61 72 |lass-id |ad-clear|
|00003c20| 2d 63 61 63 68 65 5d 20 | 35 20 28 23 24 20 2e 20 |-cache] |5 (#$ . |
|00003c30| 31 34 32 36 36 29 5d 29 | 0a 28 64 65 66 61 6c 69 |14266)])|.(defali|
|00003c40| 61 73 20 27 61 64 2d 6d | 61 63 72 6f 66 79 20 27 |as 'ad-m|acrofy '|
|00003c50| 28 6d 61 63 72 6f 20 2e | 20 23 5b 28 64 65 66 69 |(macro .| #[(defi|
|00003c60| 6e 69 74 69 6f 6e 29 20 | 22 c0 c1 5c 6e 45 87 22 |nition) |"..\nE."|
|00003c70| 20 5b 63 6f 6e 73 20 27 | 6d 61 63 72 6f 20 64 65 | [cons '|macro de|
|00003c80| 66 69 6e 69 74 69 6f 6e | 5d 20 33 5d 29 29 0a 28 |finition|] 3])).(|
|00003c90| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 6c 61 6d |defalias| 'ad-lam|
|00003ca0| 62 64 61 66 79 20 27 28 | 6d 61 63 72 6f 20 2e 20 |bdafy '(|macro . |
|00003cb0| 23 5b 28 64 65 66 69 6e | 69 74 69 6f 6e 29 20 22 |#[(defin|ition) "|
|00003cc0| c0 09 44 87 22 20 5b 63 | 64 72 20 64 65 66 69 6e |..D." [c|dr defin|
|00003cd0| 69 74 69 6f 6e 5d 20 32 | 5d 29 29 0a 28 62 79 74 |ition] 2|])).(byt|
|00003ce0| 65 2d 63 6f 64 65 20 22 | c0 c1 21 ac 85 c2 c3 c4 |e-code "|..!.....|
|00003cf0| 5c 22 11 c1 0d 42 15 c0 | 87 22 20 5b 62 6f 75 6e |\"...B..|." [boun|
|00003d00| 64 70 20 61 64 2d 73 70 | 65 63 69 61 6c 2d 66 6f |dp ad-sp|ecial-fo|
|00003d10| 72 6d 73 20 6d 61 70 63 | 61 72 20 73 79 6d 62 6f |rms mapc|ar symbo|
|00003d20| 6c 2d 66 75 6e 63 74 69 | 6f 6e 20 28 61 6e 64 20 |l-functi|on (and |
|00003d30| 63 61 74 63 68 20 63 6f | 6e 64 20 63 6f 6e 64 69 |catch co|nd condi|
|00003d40| 74 69 6f 6e 2d 63 61 73 | 65 20 64 65 66 63 6f 6e |tion-cas|e defcon|
|00003d50| 73 74 20 64 65 66 6d 61 | 63 72 6f 20 64 65 66 75 |st defma|cro defu|
|00003d60| 6e 20 64 65 66 76 61 72 | 20 66 75 6e 63 74 69 6f |n defvar| functio|
|00003d70| 6e 20 69 66 20 69 6e 74 | 65 72 61 63 74 69 76 65 |n if int|eractive|
|00003d80| 20 6c 65 74 20 6c 65 74 | 2a 20 6f 72 20 70 72 6f | let let|* or pro|
|00003d90| 67 31 20 70 72 6f 67 32 | 20 70 72 6f 67 6e 20 71 |g1 prog2| progn q|
|00003da0| 75 6f 74 65 20 73 61 76 | 65 2d 65 78 63 75 72 73 |uote sav|e-excurs|
|00003db0| 69 6f 6e 20 73 61 76 65 | 2d 72 65 73 74 72 69 63 |ion save|-restric|
|00003dc0| 74 69 6f 6e 20 73 61 76 | 65 2d 77 69 6e 64 6f 77 |tion sav|e-window|
|00003dd0| 2d 65 78 63 75 72 73 69 | 6f 6e 20 73 65 74 71 20 |-excursi|on setq |
|00003de0| 73 65 74 71 2d 64 65 66 | 61 75 6c 74 20 75 6e 77 |setq-def|ault unw|
|00003df0| 69 6e 64 2d 70 72 6f 74 | 65 63 74 20 77 68 69 6c |ind-prot|ect whil|
|00003e00| 65 20 77 69 74 68 2d 6f | 75 74 70 75 74 2d 74 6f |e with-o|utput-to|
|00003e10| 2d 74 65 6d 70 2d 62 75 | 66 66 65 72 29 20 63 75 |-temp-bu|ffer) cu|
|00003e20| 72 72 65 6e 74 2d 6c 6f | 61 64 2d 6c 69 73 74 5d |rrent-lo|ad-list]|
|00003e30| 20 33 29 0a 28 64 65 66 | 61 6c 69 61 73 20 27 61 | 3).(def|alias 'a|
|00003e40| 64 2d 73 70 65 63 69 61 | 6c 2d 66 6f 72 6d 2d 70 |d-specia|l-form-p|
|00003e50| 20 27 28 6d 61 63 72 6f | 20 2e 20 23 5b 28 64 65 | '(macro| . #[(de|
|00003e60| 66 69 6e 69 74 69 6f 6e | 29 20 22 c0 09 c2 45 87 |finition|) "...E.|
|00003e70| 22 20 5b 6d 65 6d 71 20 | 64 65 66 69 6e 69 74 69 |" [memq |definiti|
|00003e80| 6f 6e 20 61 64 2d 73 70 | 65 63 69 61 6c 2d 66 6f |on ad-sp|ecial-fo|
|00003e90| 72 6d 73 5d 20 33 5d 29 | 29 0a 28 64 65 66 61 6c |rms] 3])|).(defal|
|00003ea0| 69 61 73 20 27 61 64 2d | 69 6e 74 65 72 61 63 74 |ias 'ad-|interact|
|00003eb0| 69 76 65 2d 70 20 27 28 | 6d 61 63 72 6f 20 2e 20 |ive-p '(|macro . |
|00003ec0| 23 5b 28 64 65 66 69 6e | 69 74 69 6f 6e 29 20 22 |#[(defin|ition) "|
|00003ed0| c0 09 44 87 22 20 5b 63 | 6f 6d 6d 61 6e 64 70 20 |..D." [c|ommandp |
|00003ee0| 64 65 66 69 6e 69 74 69 | 6f 6e 5d 20 32 5d 29 29 |definiti|on] 2]))|
|00003ef0| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 73 |.(defali|as 'ad-s|
|00003f00| 75 62 72 2d 70 20 27 28 | 6d 61 63 72 6f 20 2e 20 |ubr-p '(|macro . |
|00003f10| 23 5b 28 64 65 66 69 6e | 69 74 69 6f 6e 29 20 22 |#[(defin|ition) "|
|00003f20| c0 09 44 87 22 20 5b 73 | 75 62 72 70 20 64 65 66 |..D." [s|ubrp def|
|00003f30| 69 6e 69 74 69 6f 6e 5d | 20 32 5d 29 29 0a 28 64 |inition]| 2])).(d|
|00003f40| 65 66 61 6c 69 61 73 20 | 27 61 64 2d 6d 61 63 72 |efalias |'ad-macr|
|00003f50| 6f 2d 70 20 27 28 6d 61 | 63 72 6f 20 2e 20 23 5b |o-p '(ma|cro . #[|
|00003f60| 28 64 65 66 69 6e 69 74 | 69 6f 6e 29 20 22 c0 c1 |(definit|ion) "..|
|00003f70| 5c 6e 44 c3 42 42 87 22 | 20 5b 65 71 20 63 61 72 |\nD.BB."| [eq car|
|00003f80| 2d 73 61 66 65 20 64 65 | 66 69 6e 69 74 69 6f 6e |-safe de|finition|
|00003f90| 20 28 27 6d 61 63 72 6f | 29 5d 20 33 5d 29 29 0a | ('macro|)] 3])).|
|00003fa0| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 6c 61 |(defalia|s 'ad-la|
|00003fb0| 6d 62 64 61 2d 70 20 27 | 28 6d 61 63 72 6f 20 2e |mbda-p '|(macro .|
|00003fc0| 20 23 5b 28 64 65 66 69 | 6e 69 74 69 6f 6e 29 20 | #[(defi|nition) |
|00003fd0| 22 c0 c1 5c 6e 44 c3 42 | 42 87 22 20 5b 65 71 20 |"..\nD.B|B." [eq |
|00003fe0| 63 61 72 2d 73 61 66 65 | 20 64 65 66 69 6e 69 74 |car-safe| definit|
|00003ff0| 69 6f 6e 20 28 27 6c 61 | 6d 62 64 61 29 5d 20 33 |ion ('la|mbda)] 3|
|00004000| 5d 29 29 0a 28 64 65 66 | 61 6c 69 61 73 20 27 61 |])).(def|alias 'a|
|00004010| 64 2d 61 64 76 69 63 65 | 2d 70 20 27 28 6d 61 63 |d-advice|-p '(mac|
|00004020| 72 6f 20 2e 20 23 5b 28 | 64 65 66 69 6e 69 74 69 |ro . #[(|definiti|
|00004030| 6f 6e 29 20 22 c0 c1 5c | 6e 44 c3 42 42 87 22 20 |on) "..\|nD.BB." |
|00004040| 5b 65 71 20 63 61 72 2d | 73 61 66 65 20 64 65 66 |[eq car-|safe def|
|00004050| 69 6e 69 74 69 6f 6e 20 | 28 27 61 64 76 69 63 65 |inition |('advice|
|00004060| 29 5d 20 33 5d 29 29 0a | 28 62 79 74 65 2d 63 6f |)] 3])).|(byte-co|
|00004070| 64 65 20 22 c0 c1 21 ac | 8a c0 c2 21 ab 85 c3 c1 |de "..!.|...!....|
|00004080| c2 5c 22 88 c0 87 22 20 | 5b 66 62 6f 75 6e 64 70 |.\"..." |[fboundp|
|00004090| 20 62 79 74 65 2d 63 6f | 64 65 2d 66 75 6e 63 74 | byte-co|de-funct|
|000040a0| 69 6f 6e 2d 70 20 63 6f | 6d 70 69 6c 65 64 2d 66 |ion-p co|mpiled-f|
|000040b0| 75 6e 63 74 69 6f 6e 2d | 70 20 61 64 2d 73 61 66 |unction-|p ad-saf|
|000040c0| 65 2d 66 73 65 74 5d 20 | 33 29 0a 28 64 65 66 61 |e-fset] |3).(defa|
|000040d0| 6c 69 61 73 20 27 61 64 | 2d 63 6f 6d 70 69 6c 65 |lias 'ad|-compile|
|000040e0| 64 2d 70 20 27 28 6d 61 | 63 72 6f 20 2e 20 23 5b |d-p '(ma|cro . #[|
|000040f0| 28 64 65 66 69 6e 69 74 | 69 6f 6e 29 20 22 c0 c1 |(definit|ion) "..|
|00004100| 5c 6e 44 c3 c4 5c 6e 44 | c1 c5 5c 6e 44 44 45 45 |\nD..\nD|..\nDDEE|
|00004110| 87 22 20 5b 6f 72 20 62 | 79 74 65 2d 63 6f 64 65 |." [or b|yte-code|
|00004120| 2d 66 75 6e 63 74 69 6f | 6e 2d 70 20 64 65 66 69 |-functio|n-p defi|
|00004130| 6e 69 74 69 6f 6e 20 61 | 6e 64 20 61 64 2d 6d 61 |nition a|nd ad-ma|
|00004140| 63 72 6f 2d 70 20 61 64 | 2d 6c 61 6d 62 64 61 66 |cro-p ad|-lambdaf|
|00004150| 79 5d 20 37 5d 29 29 0a | 28 64 65 66 61 6c 69 61 |y] 7])).|(defalia|
|00004160| 73 20 27 61 64 2d 63 6f | 6d 70 69 6c 65 64 2d 63 |s 'ad-co|mpiled-c|
|00004170| 6f 64 65 20 27 28 6d 61 | 63 72 6f 20 2e 20 23 5b |ode '(ma|cro . #[|
|00004180| 28 63 6f 6d 70 69 6c 65 | 64 2d 64 65 66 69 6e 69 |(compile|d-defini|
|00004190| 74 69 6f 6e 29 20 22 c0 | c1 5c 6e 44 c3 5c 6e 44 |tion) ".|.\nD.\nD|
|000041a0| 5c 6e 46 87 22 20 5b 69 | 66 20 61 64 2d 6d 61 63 |\nF." [i|f ad-mac|
|000041b0| 72 6f 2d 70 20 63 6f 6d | 70 69 6c 65 64 2d 64 65 |ro-p com|piled-de|
|000041c0| 66 69 6e 69 74 69 6f 6e | 20 61 64 2d 6c 61 6d 62 |finition| ad-lamb|
|000041d0| 64 61 66 79 5d 20 34 5d | 29 29 0a 28 64 65 66 61 |dafy] 4]|)).(defa|
|000041e0| 6c 69 61 73 20 27 61 64 | 2d 6c 61 6d 62 64 61 2d |lias 'ad|-lambda-|
|000041f0| 65 78 70 72 65 73 73 69 | 6f 6e 20 23 5b 28 64 65 |expressi|on #[(de|
|00004200| 66 69 6e 69 74 69 6f 6e | 29 20 22 08 a2 c1 61 ab |finition|) "...a.|
|00004210| 82 08 87 08 a2 c2 61 ab | 83 08 41 87 08 a2 c3 61 |......a.|..A....a|
|00004220| ab 83 08 41 87 c4 87 22 | 20 5b 64 65 66 69 6e 69 |...A..."| [defini|
|00004230| 74 69 6f 6e 20 6c 61 6d | 62 64 61 20 6d 61 63 72 |tion lam|bda macr|
|00004240| 6f 20 61 64 76 69 63 65 | 20 6e 69 6c 5d 20 32 5d |o advice| nil] 2]|
|00004250| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00004260| 61 72 67 6c 69 73 74 20 | 23 5b 28 64 65 66 69 6e |arglist |#[(defin|
|00004270| 69 74 69 6f 6e 20 26 6f | 70 74 69 6f 6e 61 6c 20 |ition &o|ptional |
|00004280| 6e 61 6d 65 29 20 22 c0 | 09 21 ac 8c 09 a2 c2 61 |name) ".|.!.....a|
|00004290| ab a7 c0 09 41 21 ab a1 | c3 c4 21 ab 8e c4 09 a2 |....A!..|..!.....|
|000042a0| c2 61 ab 84 09 41 aa 81 | 09 21 87 09 a2 c2 61 ab |.a...A..|.!....a.|
|000042b0| 84 09 41 aa 81 09 c5 48 | 87 09 3a ab 86 c6 09 21 |..A....H|..:....!|
|000042c0| 41 40 87 c7 09 21 ad a0 | 0e 08 ab 85 c9 0e 08 21 |A@...!..|.......!|
|000042d0| 87 ca cb 09 5c 22 16 08 | cc cd 0e 08 5c 22 88 c9 |....\"..|....\"..|
|000042e0| ce 0e 08 cf 94 cf 95 4f | 21 21 87 22 20 5b 62 79 |.......O|!!." [by|
|000042f0| 74 65 2d 63 6f 64 65 2d | 66 75 6e 63 74 69 6f 6e |te-code-|function|
|00004300| 2d 70 20 64 65 66 69 6e | 69 74 69 6f 6e 20 6d 61 |-p defin|ition ma|
|00004310| 63 72 6f 20 66 62 6f 75 | 6e 64 70 20 63 6f 6d 70 |cro fbou|ndp comp|
|00004320| 69 6c 65 64 2d 66 75 6e | 63 74 69 6f 6e 2d 61 72 |iled-fun|ction-ar|
|00004330| 67 6c 69 73 74 20 30 20 | 61 64 2d 6c 61 6d 62 64 |glist 0 |ad-lambd|
|00004340| 61 2d 65 78 70 72 65 73 | 73 69 6f 6e 20 73 75 62 |a-expres|sion sub|
|00004350| 72 70 20 6e 61 6d 65 20 | 61 64 2d 73 75 62 72 2d |rp name |ad-subr-|
|00004360| 61 72 67 6c 69 73 74 20 | 66 6f 72 6d 61 74 20 22 |arglist |format "|
|00004370| 25 73 22 20 73 74 72 69 | 6e 67 2d 6d 61 74 63 68 |%s" stri|ng-match|
|00004380| 20 22 5e 23 3c 73 75 62 | 72 20 5c 5c 28 5b 5e 3e | "^#<sub|r \\([^>|
|00004390| 5d 2b 5c 5c 29 3e 24 22 | 20 69 6e 74 65 72 6e 20 |]+\\)>$"| intern |
|000043a0| 31 5d 20 35 5d 29 0a 28 | 64 65 66 61 6c 69 61 73 |1] 5]).(|defalias|
|000043b0| 20 27 61 64 2d 64 65 66 | 69 6e 65 2d 73 75 62 72 | 'ad-def|ine-subr|
|000043c0| 2d 61 72 67 73 20 27 28 | 6d 61 63 72 6f 20 2e 20 |-args '(|macro . |
|000043d0| 23 5b 28 73 75 62 72 20 | 61 72 67 6c 69 73 74 29 |#[(subr |arglist)|
|000043e0| 20 22 c0 09 c2 c3 0c 44 | 46 87 22 20 5b 70 75 74 | ".....D|F." [put|
|000043f0| 20 73 75 62 72 20 27 61 | 64 2d 73 75 62 72 2d 61 | subr 'a|d-subr-a|
|00004400| 72 67 6c 69 73 74 20 6c | 69 73 74 20 61 72 67 6c |rglist l|ist argl|
|00004410| 69 73 74 5d 20 35 5d 29 | 29 0a 28 64 65 66 61 6c |ist] 5])|).(defal|
|00004420| 69 61 73 20 27 61 64 2d | 75 6e 64 65 66 69 6e 65 |ias 'ad-|undefine|
|00004430| 2d 73 75 62 72 2d 61 72 | 67 73 20 27 28 6d 61 63 |-subr-ar|gs '(mac|
|00004440| 72 6f 20 2e 20 23 5b 28 | 73 75 62 72 29 20 22 c0 |ro . #[(|subr) ".|
|00004450| 09 c2 42 42 87 22 20 5b | 70 75 74 20 73 75 62 72 |..BB." [|put subr|
|00004460| 20 28 27 61 64 2d 73 75 | 62 72 2d 61 72 67 6c 69 | ('ad-su|br-argli|
|00004470| 73 74 20 6e 69 6c 29 5d | 20 33 5d 29 29 0a 28 64 |st nil)]| 3])).(d|
|00004480| 65 66 61 6c 69 61 73 20 | 27 61 64 2d 73 75 62 72 |efalias |'ad-subr|
|00004490| 2d 61 72 67 73 2d 64 65 | 66 69 6e 65 64 2d 70 20 |-args-de|fined-p |
|000044a0| 27 28 6d 61 63 72 6f 20 | 2e 20 23 5b 28 73 75 62 |'(macro |. #[(sub|
|000044b0| 72 29 20 22 c0 09 c2 42 | 42 87 22 20 5b 67 65 74 |r) "...B|B." [get|
|000044c0| 20 73 75 62 72 20 28 27 | 61 64 2d 73 75 62 72 2d | subr ('|ad-subr-|
|000044d0| 61 72 67 6c 69 73 74 29 | 5d 20 33 5d 29 29 0a 28 |arglist)|] 3])).(|
|000044e0| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 67 65 74 |defalias| 'ad-get|
|000044f0| 2d 73 75 62 72 2d 61 72 | 67 73 20 27 28 6d 61 63 |-subr-ar|gs '(mac|
|00004500| 72 6f 20 2e 20 23 5b 28 | 73 75 62 72 29 20 22 c0 |ro . #[(|subr) ".|
|00004510| c1 5c 6e c3 42 42 44 87 | 22 20 5b 63 61 72 20 67 |.\n.BBD.|" [car g|
|00004520| 65 74 20 73 75 62 72 20 | 28 27 61 64 2d 73 75 62 |et subr |('ad-sub|
|00004530| 72 2d 61 72 67 6c 69 73 | 74 29 5d 20 34 5d 29 29 |r-arglis|t)] 4]))|
|00004540| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 73 |.(defali|as 'ad-s|
|00004550| 75 62 72 2d 61 72 67 6c | 69 73 74 20 23 5b 28 73 |ubr-argl|ist #[(s|
|00004560| 75 62 72 2d 6e 61 6d 65 | 29 20 22 08 c1 4e ab 85 |ubr-name|) "..N..|
|00004570| 08 c1 4e 40 87 c2 08 c3 | 5c 22 ae 81 c4 1d c6 c7 |..N@....|\"......|
|00004580| 0d 5c 22 ab 96 c8 08 c1 | c9 0d ca 94 ca 95 4f 97 |.\".....|......O.|
|00004590| 21 40 43 23 88 08 c1 4e | 40 aa 9e c6 cb 0d 5c 22 |!@C#...N|@.....\"|
|000045a0| ab 97 c8 08 c1 c9 0d ca | 94 ca 95 4f 97 21 40 41 |........|...O.!@A|
|000045b0| 43 23 88 08 c1 4e 40 aa | 81 cc 29 87 22 20 5b 73 |C#...N@.|..)." [s|
|000045c0| 75 62 72 2d 6e 61 6d 65 | 20 61 64 2d 73 75 62 72 |ubr-name| ad-subr|
|000045d0| 2d 61 72 67 6c 69 73 74 | 20 61 64 2d 72 65 61 6c |-arglist| ad-real|
|000045e0| 2d 64 6f 63 75 6d 65 6e | 74 61 74 69 6f 6e 20 74 |-documen|tation t|
|000045f0| 20 22 22 20 64 6f 63 20 | 73 74 72 69 6e 67 2d 6d | "" doc |string-m|
|00004600| 61 74 63 68 20 22 5b 5c | 6e 09 20 5d 2a 5c 6e 61 |atch "[\|n. ]*\na|
|00004610| 72 67 75 6d 65 6e 74 73 | 3a 20 3f 5c 5c 28 28 2e |rguments|: ?\\((.|
|00004620| 2a 29 5c 5c 29 5c 6e 3f | 5c 5c 27 22 20 70 75 74 |*)\\)\n?|\\'" put|
|00004630| 20 72 65 61 64 2d 66 72 | 6f 6d 2d 73 74 72 69 6e | read-fr|om-strin|
|00004640| 67 20 31 20 22 5e 5c 5c | 28 28 5b 5e 29 5d 2b 29 |g 1 "^\\|(([^)]+)|
|00004650| 5c 5c 29 5c 6e 3f 5c 5c | 27 22 20 28 26 72 65 73 |\\)\n?\\|'" (&res|
|00004660| 74 20 61 64 2d 73 75 62 | 72 2d 61 72 67 73 29 5d |t ad-sub|r-args)]|
|00004670| 20 37 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 7]).(de|falias '|
|00004680| 61 64 2d 64 6f 63 73 74 | 72 69 6e 67 20 23 5b 28 |ad-docst|ring #[(|
|00004690| 64 65 66 69 6e 69 74 69 | 6f 6e 29 20 22 c0 09 21 |definiti|on) "..!|
|000046a0| ac 8c 09 a2 c2 61 ab 8c | c0 09 41 21 ab 86 c3 09 |.....a..|..A!....|
|000046b0| c4 5c 22 aa 86 c5 09 21 | 41 41 40 89 1e 06 3b ac |.\"....!|AA@...;.|
|000046c0| 86 c7 0e 06 21 ad 82 0e | 06 29 87 22 20 5b 62 79 |....!...|.)." [by|
|000046d0| 74 65 2d 63 6f 64 65 2d | 66 75 6e 63 74 69 6f 6e |te-code-|function|
|000046e0| 2d 70 20 64 65 66 69 6e | 69 74 69 6f 6e 20 6d 61 |-p defin|ition ma|
|000046f0| 63 72 6f 20 61 64 2d 72 | 65 61 6c 2d 64 6f 63 75 |cro ad-r|eal-docu|
|00004700| 6d 65 6e 74 61 74 69 6f | 6e 20 74 20 61 64 2d 6c |mentatio|n t ad-l|
|00004710| 61 6d 62 64 61 2d 65 78 | 70 72 65 73 73 69 6f 6e |ambda-ex|pression|
|00004720| 20 64 6f 63 73 74 72 69 | 6e 67 20 6e 61 74 6e 75 | docstri|ng natnu|
|00004730| 6d 70 5d 20 34 5d 29 0a | 28 64 65 66 61 6c 69 61 |mp] 4]).|(defalia|
|00004740| 73 20 27 61 64 2d 69 6e | 74 65 72 61 63 74 69 76 |s 'ad-in|teractiv|
|00004750| 65 2d 66 6f 72 6d 20 23 | 5b 28 64 65 66 69 6e 69 |e-form #|[(defini|
|00004760| 74 69 6f 6e 29 20 22 c0 | 09 21 ac 8c 09 a2 c2 61 |tion) ".|.!.....a|
|00004770| ab ae c0 09 41 21 ab a8 | c3 09 21 ad b4 c4 c5 21 |....A!..|..!....!|
|00004780| ab 8e c5 09 a2 c2 61 ab | 84 09 41 aa 81 09 21 87 |......a.|..A...!.|
|00004790| c6 09 a2 c2 61 ab 84 09 | 41 aa 81 09 c7 48 44 87 |....a...|A....HD.|
|000047a0| 09 a2 c8 61 ac 86 09 a2 | c9 61 ad 85 c3 ca 09 21 |...a....|.a.....!|
|000047b0| 21 87 22 20 5b 62 79 74 | 65 2d 63 6f 64 65 2d 66 |!." [byt|e-code-f|
|000047c0| 75 6e 63 74 69 6f 6e 2d | 70 20 64 65 66 69 6e 69 |unction-|p defini|
|000047d0| 74 69 6f 6e 20 6d 61 63 | 72 6f 20 63 6f 6d 6d 61 |tion mac|ro comma|
|000047e0| 6e 64 70 20 66 62 6f 75 | 6e 64 70 20 63 6f 6d 70 |ndp fbou|ndp comp|
|000047f0| 69 6c 65 64 2d 66 75 6e | 63 74 69 6f 6e 2d 69 6e |iled-fun|ction-in|
|00004800| 74 65 72 61 63 74 69 76 | 65 20 69 6e 74 65 72 61 |teractiv|e intera|
|00004810| 63 74 69 76 65 20 35 20 | 61 64 76 69 63 65 20 6c |ctive 5 |advice l|
|00004820| 61 6d 62 64 61 20 61 64 | 2d 6c 61 6d 62 64 61 2d |ambda ad|-lambda-|
|00004830| 65 78 70 72 65 73 73 69 | 6f 6e 5d 20 33 5d 29 0a |expressi|on] 3]).|
|00004840| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 62 6f |(defalia|s 'ad-bo|
|00004850| 64 79 2d 66 6f 72 6d 73 | 20 23 5b 28 64 65 66 69 |dy-forms| #[(defi|
|00004860| 6e 69 74 69 6f 6e 29 20 | 22 c0 09 21 ac 8c 09 a2 |nition) |"..!....|
|00004870| c2 61 ab 88 c0 09 41 21 | ab 82 c3 87 09 3a ad 99 |.a....A!|.....:..|
|00004880| c4 09 21 ab 83 c5 aa 81 | c6 c7 09 21 ab 83 c5 aa |..!.....|...!....|
|00004890| 81 c6 5c 5c c8 09 21 41 | 41 9b 87 22 20 5b 62 79 |..\\..!A|A.." [by|
|000048a0| 74 65 2d 63 6f 64 65 2d | 66 75 6e 63 74 69 6f 6e |te-code-|function|
|000048b0| 2d 70 20 64 65 66 69 6e | 69 74 69 6f 6e 20 6d 61 |-p defin|ition ma|
|000048c0| 63 72 6f 20 6e 69 6c 20 | 61 64 2d 64 6f 63 73 74 |cro nil |ad-docst|
|000048d0| 72 69 6e 67 20 31 20 30 | 20 61 64 2d 69 6e 74 65 |ring 1 0| ad-inte|
|000048e0| 72 61 63 74 69 76 65 2d | 66 6f 72 6d 20 61 64 2d |ractive-|form ad-|
|000048f0| 6c 61 6d 62 64 61 2d 65 | 78 70 72 65 73 73 69 6f |lambda-e|xpressio|
|00004900| 6e 5d 20 33 5d 29 0a 28 | 62 79 74 65 2d 63 6f 64 |n] 3]).(|byte-cod|
|00004910| 65 20 22 c0 c1 21 ac 82 | c2 11 c1 0b 42 13 c0 87 |e "..!..|....B...|
|00004920| 22 20 5b 62 6f 75 6e 64 | 70 20 61 64 2d 61 64 76 |" [bound|p ad-adv|
|00004930| 69 73 65 64 2d 64 65 66 | 69 6e 69 74 69 6f 6e 2d |ised-def|inition-|
|00004940| 64 6f 63 73 74 72 69 6e | 67 2d 72 65 67 65 78 70 |docstrin|g-regexp|
|00004950| 20 22 5e 5c 5c 24 61 64 | 2d 64 6f 63 3a 20 5c 5c | "^\\$ad|-doc: \\|
|00004960| 28 2e 2b 5c 5c 29 5c 5c | 24 24 22 20 63 75 72 72 |(.+\\)\\|$$" curr|
|00004970| 65 6e 74 2d 6c 6f 61 64 | 2d 6c 69 73 74 5d 20 32 |ent-load|-list] 2|
|00004980| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00004990| 6d 61 6b 65 2d 61 64 76 | 69 73 65 64 2d 64 65 66 |make-adv|ised-def|
|000049a0| 69 6e 69 74 69 6f 6e 2d | 64 6f 63 73 74 72 69 6e |inition-|docstrin|
|000049b0| 67 20 23 5b 28 66 75 6e | 63 74 69 6f 6e 29 20 22 |g #[(fun|ction) "|
|000049c0| c0 c1 c2 0b 21 5c 22 87 | 22 20 5b 66 6f 72 6d 61 |....!\".|" [forma|
|000049d0| 74 20 22 24 61 64 2d 64 | 6f 63 3a 20 25 73 24 22 |t "$ad-d|oc: %s$"|
|000049e0| 20 70 72 69 6e 31 2d 74 | 6f 2d 73 74 72 69 6e 67 | prin1-t|o-string|
|000049f0| 20 66 75 6e 63 74 69 6f | 6e 5d 20 34 5d 29 0a 28 | functio|n] 4]).(|
|00004a00| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 61 64 76 |defalias| 'ad-adv|
|00004a10| 69 73 65 64 2d 64 65 66 | 69 6e 69 74 69 6f 6e 2d |ised-def|inition-|
|00004a20| 70 20 23 5b 28 64 65 66 | 69 6e 69 74 69 6f 6e 29 |p #[(def|inition)|
|00004a30| 20 22 08 a2 c1 61 ac 97 | 08 a2 c2 61 ac 91 c3 08 | "...a..|...a....|
|00004a40| 21 ac 8c 08 a2 c2 61 ad | 94 c3 08 41 21 ad 8e c4 |!.....a.|...A!...|
|00004a50| 08 21 89 1d 3b ad 85 c6 | 0e 07 0d 5c 22 29 87 22 |.!..;...|...\")."|
|00004a60| 20 5b 64 65 66 69 6e 69 | 74 69 6f 6e 20 6c 61 6d | [defini|tion lam|
|00004a70| 62 64 61 20 6d 61 63 72 | 6f 20 62 79 74 65 2d 63 |bda macr|o byte-c|
|00004a80| 6f 64 65 2d 66 75 6e 63 | 74 69 6f 6e 2d 70 20 61 |ode-func|tion-p a|
|00004a90| 64 2d 64 6f 63 73 74 72 | 69 6e 67 20 64 6f 63 73 |d-docstr|ing docs|
|00004aa0| 74 72 69 6e 67 20 73 74 | 72 69 6e 67 2d 6d 61 74 |tring st|ring-mat|
|00004ab0| 63 68 20 61 64 2d 61 64 | 76 69 73 65 64 2d 64 65 |ch ad-ad|vised-de|
|00004ac0| 66 69 6e 69 74 69 6f 6e | 2d 64 6f 63 73 74 72 69 |finition|-docstri|
|00004ad0| 6e 67 2d 72 65 67 65 78 | 70 5d 20 34 5d 29 0a 28 |ng-regex|p] 4]).(|
|00004ae0| 64 65 66 61 6c 69 61 73 | 20 27 61 64 2d 64 65 66 |defalias| 'ad-def|
|00004af0| 69 6e 69 74 69 6f 6e 2d | 74 79 70 65 20 23 5b 28 |inition-|type #[(|
|00004b00| 64 65 66 69 6e 69 74 69 | 6f 6e 29 20 22 08 a2 c1 |definiti|on) "...|
|00004b10| 61 ab 82 c1 87 c2 08 21 | ab 89 08 0b 73 ab 82 c4 |a......!|....s...|
|00004b20| 87 c5 87 08 a2 c6 61 ac | 91 c7 08 21 ac 8c 08 a2 |......a.|...!....|
|00004b30| c1 61 ab 88 c7 08 41 21 | ab 82 c8 87 08 a2 c9 61 |.a....A!|.......a|
|00004b40| ad 81 c9 87 22 20 5b 64 | 65 66 69 6e 69 74 69 6f |...." [d|efinitio|
|00004b50| 6e 20 6d 61 63 72 6f 20 | 73 75 62 72 70 20 61 64 |n macro |subrp ad|
|00004b60| 2d 73 70 65 63 69 61 6c | 2d 66 6f 72 6d 73 20 73 |-special|-forms s|
|00004b70| 70 65 63 69 61 6c 2d 66 | 6f 72 6d 20 73 75 62 72 |pecial-f|orm subr|
|00004b80| 20 6c 61 6d 62 64 61 20 | 62 79 74 65 2d 63 6f 64 | lambda |byte-cod|
|00004b90| 65 2d 66 75 6e 63 74 69 | 6f 6e 2d 70 20 66 75 6e |e-functi|on-p fun|
|00004ba0| 63 74 69 6f 6e 20 61 64 | 76 69 63 65 5d 20 32 5d |ction ad|vice] 2]|
|00004bb0| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00004bc0| 68 61 73 2d 70 72 6f 70 | 65 72 2d 64 65 66 69 6e |has-prop|er-defin|
|00004bd0| 69 74 69 6f 6e 20 23 5b | 28 66 75 6e 63 74 69 6f |ition #[|(functio|
|00004be0| 6e 29 20 22 08 39 ad 8b | c1 08 21 ad 86 08 4b a2 |n) ".9..|..!...K.|
|00004bf0| c2 61 3f 87 22 20 5b 66 | 75 6e 63 74 69 6f 6e 20 |.a?." [f|unction |
|00004c00| 66 62 6f 75 6e 64 70 20 | 61 75 74 6f 6c 6f 61 64 |fboundp |autoload|
|00004c10| 5d 20 32 5d 29 0a 28 64 | 65 66 61 6c 69 61 73 20 |] 2]).(d|efalias |
|00004c20| 27 61 64 2d 72 65 61 6c | 2d 64 65 66 69 6e 69 74 |'ad-real|-definit|
|00004c30| 69 6f 6e 20 23 5b 28 66 | 75 6e 63 74 69 6f 6e 29 |ion #[(f|unction)|
|00004c40| 20 22 c0 09 21 ad 8e 09 | 4b 89 1a 39 ab 85 c3 5c | "..!...|K..9...\|
|00004c50| 6e 21 aa 81 5c 6e 29 87 | 22 20 5b 61 64 2d 68 61 |n!..\n).|" [ad-ha|
|00004c60| 73 2d 70 72 6f 70 65 72 | 2d 64 65 66 69 6e 69 74 |s-proper|-definit|
|00004c70| 69 6f 6e 20 66 75 6e 63 | 74 69 6f 6e 20 64 65 66 |ion func|tion def|
|00004c80| 69 6e 69 74 69 6f 6e 20 | 61 64 2d 72 65 61 6c 2d |inition |ad-real-|
|00004c90| 64 65 66 69 6e 69 74 69 | 6f 6e 5d 20 33 5d 29 0a |definiti|on] 3]).|
|00004ca0| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 72 65 |(defalia|s 'ad-re|
|00004cb0| 61 6c 2d 6f 72 69 67 2d | 64 65 66 69 6e 69 74 69 |al-orig-|definiti|
|00004cc0| 6f 6e 20 23 5b 28 66 75 | 6e 63 74 69 6f 6e 29 20 |on #[(fu|nction) |
|00004cd0| 22 08 c1 4e ad 88 c2 c3 | 08 c1 4e b7 41 21 87 22 |"..N....|..N.A!."|
|00004ce0| 20 5b 66 75 6e 63 74 69 | 6f 6e 20 61 64 2d 61 64 | [functi|on ad-ad|
|00004cf0| 76 69 63 65 2d 69 6e 66 | 6f 20 61 64 2d 72 65 61 |vice-inf|o ad-rea|
|00004d00| 6c 2d 64 65 66 69 6e 69 | 74 69 6f 6e 20 6f 72 69 |l-defini|tion ori|
|00004d10| 67 6e 61 6d 65 5d 20 34 | 5d 29 0a 28 64 65 66 61 |gname] 4|]).(defa|
|00004d20| 6c 69 61 73 20 27 61 64 | 2d 69 73 2d 63 6f 6d 70 |lias 'ad|-is-comp|
|00004d30| 69 6c 61 62 6c 65 20 23 | 5b 28 66 75 6e 63 74 69 |ilable #|[(functi|
|00004d40| 6f 6e 29 20 22 c0 09 21 | ad a1 09 4b a2 c2 61 ac |on) "..!|...K..a.|
|00004d50| 87 09 4b a2 c3 61 ad 93 | c4 09 4b 21 ae 8c 09 4b |..K..a..|..K!...K|
|00004d60| a2 c3 61 ad 85 c4 09 4b | 41 21 3f 87 22 20 5b 61 |..a....K|A!?." [a|
|00004d70| 64 2d 68 61 73 2d 70 72 | 6f 70 65 72 2d 64 65 66 |d-has-pr|oper-def|
|00004d80| 69 6e 69 74 69 6f 6e 20 | 66 75 6e 63 74 69 6f 6e |inition |function|
|00004d90| 20 6c 61 6d 62 64 61 20 | 6d 61 63 72 6f 20 62 79 | lambda |macro by|
|00004da0| 74 65 2d 63 6f 64 65 2d | 66 75 6e 63 74 69 6f 6e |te-code-|function|
|00004db0| 2d 70 5d 20 32 5d 29 0a | 23 40 36 32 20 42 79 74 |-p] 2]).|#@62 Byt|
|00004dc0| 65 2d 63 6f 6d 70 69 6c | 65 73 20 46 55 4e 43 54 |e-compil|es FUNCT|
|00004dd0| 49 4f 4e 20 28 6f 72 20 | 6d 61 63 72 6f 29 20 69 |ION (or |macro) i|
|00004de0| 66 20 69 74 20 69 73 20 | 6e 6f 74 20 79 65 74 20 |f it is |not yet |
|00004df0| 63 6f 6d 70 69 6c 65 64 | 2e 1f 0a 28 64 65 66 61 |compiled|...(defa|
|00004e00| 6c 69 61 73 20 27 61 64 | 2d 63 6f 6d 70 69 6c 65 |lias 'ad|-compile|
|00004e10| 2d 66 75 6e 63 74 69 6f | 6e 20 23 5b 28 66 75 6e |-functio|n #[(fun|
|00004e20| 63 74 69 6f 6e 29 20 22 | c0 09 21 ad 86 c2 1b c4 |ction) "|..!.....|
|00004e30| 09 21 29 87 22 20 5b 61 | 64 2d 69 73 2d 63 6f 6d |.!)." [a|d-is-com|
|00004e40| 70 69 6c 61 62 6c 65 20 | 66 75 6e 63 74 69 6f 6e |pilable |function|
|00004e50| 20 6e 69 6c 20 61 64 2d | 61 63 74 69 76 61 74 65 | nil ad-|activate|
|00004e60| 2d 6f 6e 2d 74 6f 70 2d | 6c 65 76 65 6c 20 62 79 |-on-top-|level by|
|00004e70| 74 65 2d 63 6f 6d 70 69 | 6c 65 5d 20 32 20 28 23 |te-compi|le] 2 (#|
|00004e80| 24 20 2e 20 31 39 39 30 | 31 29 20 22 61 42 79 74 |$ . 1990|1) "aByt|
|00004e90| 65 2d 63 6f 6d 70 69 6c | 65 20 66 75 6e 63 74 69 |e-compil|e functi|
|00004ea0| 6f 6e 3a 20 22 5d 29 0a | 28 64 65 66 61 6c 69 61 |on: "]).|(defalia|
|00004eb0| 73 20 27 61 64 2d 70 72 | 6f 67 6e 69 66 79 20 23 |s 'ad-pr|ognify #|
|00004ec0| 5b 28 66 6f 72 6d 73 29 | 20 22 08 47 c1 58 ab 83 |[(forms)| ".G.X..|
|00004ed0| 08 40 87 c2 08 42 87 22 | 20 5b 66 6f 72 6d 73 20 |.@...B."| [forms |
|00004ee0| 31 20 70 72 6f 67 6e 5d | 20 32 5d 29 0a 28 64 65 |1 progn]| 2]).(de|
|00004ef0| 66 61 6c 69 61 73 20 27 | 61 64 2d 70 61 72 73 65 |falias '|ad-parse|
|00004f00| 2d 61 72 67 6c 69 73 74 | 20 23 5b 28 61 72 67 6c |-arglist| #[(argl|
|00004f10| 69 73 74 29 20 22 c0 19 | c0 1a c0 1b c4 0d 73 41 |ist) "..|......sA|
|00004f20| 40 89 13 ab 89 c6 c4 c6 | 0d 21 73 41 21 15 c7 0d |@.......|.!sA!...|
|00004f30| 73 41 89 12 ab 8b c6 c7 | c6 0d 21 73 41 21 11 aa |sA......|..!sA!..|
|00004f40| 82 0d 11 09 5c 6e 0b 45 | 2b 87 22 20 5b 6e 69 6c |....\n.E|+." [nil|
|00004f50| 20 72 65 71 75 69 72 65 | 64 20 6f 70 74 69 6f 6e | require|d option|
|00004f60| 61 6c 20 72 65 73 74 20 | 26 72 65 73 74 20 61 72 |al rest |&rest ar|
|00004f70| 67 6c 69 73 74 20 72 65 | 76 65 72 73 65 20 26 6f |glist re|verse &o|
|00004f80| 70 74 69 6f 6e 61 6c 5d | 20 35 5d 29 0a 28 64 65 |ptional]| 5]).(de|
|00004f90| 66 61 6c 69 61 73 20 27 | 61 64 2d 72 65 74 72 69 |falias '|ad-retri|
|00004fa0| 65 76 65 2d 61 72 67 73 | 2d 66 6f 72 6d 20 23 5b |eve-args|-form #[|
|00004fb0| 28 61 72 67 6c 69 73 74 | 29 20 22 c0 09 21 1a c3 |(arglist|) "..!..|
|00004fc0| 5c 6e 38 1c c5 c6 c7 c8 | 5c 6e 40 5c 22 c7 c9 5c |\n8.....|\n@\"..\|
|00004fd0| 6e 41 40 5c 22 0c ad 8a | c5 ca 0c 44 0c cb 42 42 |nA@\"...|...D..BB|
|00004fe0| 42 43 23 2a 42 87 22 20 | 5b 61 64 2d 70 61 72 73 |BC#*B." |[ad-pars|
|00004ff0| 65 2d 61 72 67 6c 69 73 | 74 20 61 72 67 6c 69 73 |e-arglis|t arglis|
|00005000| 74 20 70 61 72 73 65 64 | 2d 61 72 67 6c 69 73 74 |t parsed|-arglist|
|00005010| 20 32 20 72 65 73 74 20 | 6c 69 73 74 20 61 70 70 | 2 rest |list app|
|00005020| 65 6e 64 20 6d 61 70 63 | 61 72 20 23 5b 28 72 65 |end mapc|ar #[(re|
|00005030| 71 29 20 22 c0 c1 5c 6e | 44 5c 6e c3 42 42 42 87 |q) "..\n|D\n.BBB.|
|00005040| 22 20 5b 6c 69 73 74 20 | 71 75 6f 74 65 20 72 65 |" [list |quote re|
|00005050| 71 20 28 27 72 65 71 75 | 69 72 65 64 29 5d 20 34 |q ('requ|ired)] 4|
|00005060| 5d 20 23 5b 28 6f 70 74 | 29 20 22 c0 c1 5c 6e 44 |] #[(opt|) "..\nD|
|00005070| 5c 6e c3 42 42 42 87 22 | 20 5b 6c 69 73 74 20 71 |\n.BBB."| [list q|
|00005080| 75 6f 74 65 20 6f 70 74 | 20 28 27 6f 70 74 69 6f |uote opt| ('optio|
|00005090| 6e 61 6c 29 5d 20 34 5d | 20 71 75 6f 74 65 20 28 |nal)] 4]| quote (|
|000050a0| 27 72 65 73 74 29 5d 20 | 38 5d 29 0a 28 64 65 66 |'rest)] |8]).(def|
|000050b0| 61 6c 69 61 73 20 27 61 | 64 2d 61 72 67 2d 62 69 |alias 'a|d-arg-bi|
|000050c0| 6e 64 69 6e 67 2d 66 69 | 65 6c 64 20 23 5b 28 62 |nding-fi|eld #[(b|
|000050d0| 69 6e 64 69 6e 67 20 66 | 69 65 6c 64 29 20 22 08 |inding f|ield) ".|
|000050e0| c1 61 ab 83 5c 6e 40 87 | 08 c3 61 ab 84 5c 6e 41 |.a..\n@.|..a..\nA|
|000050f0| 40 87 08 c4 61 ad 84 5c | 6e 41 41 40 87 22 20 5b |@...a..\|nAA@." [|
|00005100| 66 69 65 6c 64 20 6e 61 | 6d 65 20 62 69 6e 64 69 |field na|me bindi|
|00005110| 6e 67 20 76 61 6c 75 65 | 20 74 79 70 65 5d 20 32 |ng value| type] 2|
|00005120| 5d 29 0a 28 64 65 66 61 | 6c 69 61 73 20 27 61 64 |]).(defa|lias 'ad|
|00005130| 2d 6c 69 73 74 2d 61 63 | 63 65 73 73 20 23 5b 28 |-list-ac|cess #[(|
|00005140| 70 6f 73 69 74 69 6f 6e | 20 6c 69 73 74 29 20 22 |position| list) "|
|00005150| 08 c1 55 ab 82 5c 6e 87 | 08 c3 55 ab 84 c4 5c 6e |..U..\n.|..U...\n|
|00005160| 44 87 c5 08 5c 6e 45 87 | 22 20 5b 70 6f 73 69 74 |D...\nE.|" [posit|
|00005170| 69 6f 6e 20 30 20 6c 69 | 73 74 20 31 20 63 64 72 |ion 0 li|st 1 cdr|
|00005180| 20 6e 74 68 63 64 72 5d | 20 33 5d 29 0a 28 64 65 | nthcdr]| 3]).(de|
|00005190| 66 61 6c 69 61 73 20 27 | 61 64 2d 65 6c 65 6d 65 |falias '|ad-eleme|
|000051a0| 6e 74 2d 61 63 63 65 73 | 73 20 23 5b 28 70 6f 73 |nt-acces|s #[(pos|
|000051b0| 69 74 69 6f 6e 20 6c 69 | 73 74 29 20 22 08 c1 55 |ition li|st) "..U|
|000051c0| ab 84 c2 0b 44 87 08 c4 | 55 ab 86 c2 c5 0b 44 44 |....D...|U.....DD|
|000051d0| 87 c6 08 0b 45 87 22 20 | 5b 70 6f 73 69 74 69 6f |....E." |[positio|
|000051e0| 6e 20 30 20 63 61 72 20 | 6c 69 73 74 20 31 20 63 |n 0 car |list 1 c|
|000051f0| 64 72 20 6e 74 68 5d 20 | 33 5d 29 0a 28 64 65 66 |dr nth] |3]).(def|
|00005200| 61 6c 69 61 73 20 27 61 | 64 2d 61 63 63 65 73 73 |alias 'a|d-access|
|00005210| 2d 61 72 67 75 6d 65 6e | 74 20 23 5b 28 61 72 67 |-argumen|t #[(arg|
|00005220| 6c 69 73 74 20 69 6e 64 | 65 78 29 20 22 c0 09 21 |list ind|ex) "..!|
|00005230| 1a c3 5c 6e 40 5c 6e 41 | 40 5c 22 1c c5 5c 6e 38 |..\n@\nA|@\"..\n8|
|00005240| 1e 06 0e 07 0c 47 57 ab | 86 0e 07 0c 38 aa 8c 0e |.....GW.|....8...|
|00005250| 06 ad 88 0e 07 0c 47 5a | 0e 06 44 2b 87 22 20 5b |......GZ|..D+." [|
|00005260| 61 64 2d 70 61 72 73 65 | 2d 61 72 67 6c 69 73 74 |ad-parse|-arglist|
|00005270| 20 61 72 67 6c 69 73 74 | 20 70 61 72 73 65 64 2d | arglist| parsed-|
|00005280| 61 72 67 6c 69 73 74 20 | 61 70 70 65 6e 64 20 72 |arglist |append r|
|00005290| 65 71 6f 70 74 2d 61 72 | 67 73 20 32 20 72 65 73 |eqopt-ar|gs 2 res|
|000052a0| 74 2d 61 72 67 20 69 6e | 64 65 78 5d 20 33 5d 29 |t-arg in|dex] 3])|
|000052b0| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 67 |.(defali|as 'ad-g|
|000052c0| 65 74 2d 61 72 67 75 6d | 65 6e 74 20 23 5b 28 61 |et-argum|ent #[(a|
|000052d0| 72 67 6c 69 73 74 20 69 | 6e 64 65 78 29 20 22 c0 |rglist i|ndex) ".|
|000052e0| 09 5c 6e 5c 22 89 1b 3a | ab 89 c4 0b 40 0b 41 40 |.\n\"..:|....@.A@|
|000052f0| 5c 22 aa 81 0b 29 87 22 | 20 5b 61 64 2d 61 63 63 |\"...)."| [ad-acc|
|00005300| 65 73 73 2d 61 72 67 75 | 6d 65 6e 74 20 61 72 67 |ess-argu|ment arg|
|00005310| 6c 69 73 74 20 69 6e 64 | 65 78 20 61 72 67 75 6d |list ind|ex argum|
|00005320| 65 6e 74 2d 61 63 63 65 | 73 73 20 61 64 2d 65 6c |ent-acce|ss ad-el|
|00005330| 65 6d 65 6e 74 2d 61 63 | 63 65 73 73 5d 20 34 5d |ement-ac|cess] 4]|
|00005340| 29 0a 28 64 65 66 61 6c | 69 61 73 20 27 61 64 2d |).(defal|ias 'ad-|
|00005350| 73 65 74 2d 61 72 67 75 | 6d 65 6e 74 20 23 5b 28 |set-argu|ment #[(|
|00005360| 61 72 67 6c 69 73 74 20 | 69 6e 64 65 78 20 76 61 |arglist |index va|
|00005370| 6c 75 65 2d 66 6f 72 6d | 29 20 22 c0 09 5c 6e 5c |lue-form|) "..\n\|
|00005380| 22 89 1b 3a ab 8d c4 c5 | 0b 40 0b 41 40 5c 22 0e |"..:....|.@.A@\".|
|00005390| 06 45 aa 8f 0b ab 87 c7 | 0b 0e 06 45 aa 85 c8 c9 |.E......|...E....|
|000053a0| 5c 6e 09 23 29 87 22 20 | 5b 61 64 2d 61 63 63 65 |\n.#)." |[ad-acce|
|000053b0| 73 73 2d 61 72 67 75 6d | 65 6e 74 20 61 72 67 6c |ss-argum|ent argl|
|000053c0| 69 73 74 20 69 6e 64 65 | 78 20 61 72 67 75 6d 65 |ist inde|x argume|
|000053d0| 6e 74 2d 61 63 63 65 73 | 73 20 73 65 74 63 61 72 |nt-acces|s setcar|
|000053e0| 20 61 64 2d 6c 69 73 74 | 2d 61 63 63 65 73 73 20 | ad-list|-access |
|000053f0| 76 61 6c 75 65 2d 66 6f | 72 6d 20 73 65 74 71 20 |value-fo|rm setq |
|00005400| 65 72 72 6f 72 20 22 61 | 64 2d 73 65 74 2d 61 72 |error "a|d-set-ar|
|00005410| 67 75 6d 65 6e 74 3a 20 | 4e 6f 20 61 72 67 75 6d |gument: |No argum|
|00005420| 65 6e 74 20 61 74 20 70 | 6f 73 69 74 69 6f 6e 20 |ent at p|osition |
|00005430| 25 64 20 6f 66 20 60 25 | 73 27 22 5d 20 35 5d 29 |%d of `%|s'"] 5])|
|00005440| 0a 28 64 65 66 61 6c 69 | 61 73 20 27 61 64 2d 67 |.(defali|as 'ad-g|
|00005450| 65 74 2d 61 72 67 75 6d | 65 6e 74 73 20 23 5b 28 |et-argum|ents #[(|
|00005460| 61 72 67 6c 69 73 74 20 | 69 6e 64 65 78 29 20 22 |arglist |index) "|
|00005470| c0 09 21 1a c3 5c 6e 40 | 5c 6e 41 40 5c 22 1c c5 |..!..\n@|\nA@\"..|
|00005480| 5c 6e 38 1e 06 c7 1e 08 | 0e 09 0c 47 57 ab 88 ca |\n8.....|...GW...|
|00005490| 0e 09 0c 9b 42 16 08 0e | 06 ab 99 0e 08 ab 8a cb |....B...|........|
|000054a0| 0e 08 0e 06 45 16 08 aa | 8b cc 0e 09 0c 47 5a 0e |....E...|.....GZ.|
|000054b0| 06 5c 22 16 08 0e 08 2c | 87 22 20 5b 61 64 2d 70 |.\"....,|." [ad-p|
|000054c0| 61 72 73 65 2d 61 72 67 | 6c 69 73 74 20 61 72 67 |arse-arg|list arg|
|000054d0| 6c 69 73 74 20 70 61 72 | 73 65 64 2d 61 72 67 6c |list par|sed-argl|
|000054e0| 69 73 74 20 61 70 70 65 | 6e 64 20 72 65 71 6f 70 |ist appe|nd reqop|
|000054f0| 74 2d 61 72 67 73 20 32 | 20 72 65 73 74 2d 61 72 |t-args 2| rest-ar|
|00005500| 67 20 6e 69 6c 20 61 72 | 67 73 2d 66 6f 72 6d 20 |g nil ar|gs-form |
|00005510| 69 6e 64 65 78 20 6c 69 | 73 74 20 6e 63 6f 6e 63 |index li|st nconc|
|00005520| 20 61 64 2d 6c 69 73 74 | 2d 61 63 63 65 73 73 5d | ad-list|-access]|
|00005530| 20 33 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 3]).(de|falias '|
|00005540| 61 64 2d 73 65 74 2d 61 | 72 67 75 6d 65 6e 74 73 |ad-set-a|rguments|
|00005550| 20 23 5b 28 61 72 67 6c | 69 73 74 20 69 6e 64 65 | #[(argl|ist inde|
|00005560| 78 20 76 61 6c 75 65 73 | 2d 66 6f 72 6d 29 20 22 |x values|-form) "|
|00005570| c0 c1 89 1a 1b 1c c5 0e | 06 0e 07 5c 22 89 13 ab |........|...\"...|
|00005580| c2 0b 39 ab 8f c8 0e 06 | 0e 07 c9 0c ca 5c 22 23 |..9.....|.....\"#|
|00005590| 5c 6e 42 12 aa a5 0b 40 | c0 55 ab 8b cb 0b 41 40 |\nB....@|.U....A@|
|000055a0| cc 0c ca 5c 22 45 aa 8e | cd cc 0b 40 53 0b 41 40 |...\"E..|...@S.A@|
|000055b0| 5c 22 cc 0c ca 5c 22 45 | 5c 6e 42 12 c1 16 06 0e |\"...\"E|\nB.....|
|000055c0| 07 54 16 07 0c 54 14 aa | 34 5c 6e ac 89 ce cf 0e |.T...T..|4\n.....|
|000055d0| 07 0e 06 23 aa 9c 5c 6e | 47 d0 55 ab 88 d1 d2 d3 |...#..\n|G.U.....|
|000055e0| 5c 6e 40 23 aa 8e d4 ca | 0e 15 44 43 d6 d7 5c 6e |\n@#....|..DC..\n|
|000055f0| 21 d8 5c 22 42 42 2b 87 | 22 20 5b 30 20 6e 69 6c |!.\"BB+.|" [0 nil|
|00005600| 20 73 65 74 2d 66 6f 72 | 6d 73 20 61 72 67 75 6d | set-for|ms argum|
|00005610| 65 6e 74 2d 61 63 63 65 | 73 73 20 76 61 6c 75 65 |ent-acce|ss value|
|00005620| 73 2d 69 6e 64 65 78 20 | 61 64 2d 61 63 63 65 73 |s-index |ad-acces|
|00005630| 73 2d 61 72 67 75 6d 65 | 6e 74 20 61 72 67 6c 69 |s-argume|nt argli|
|00005640| 73 74 20 69 6e 64 65 78 | 20 61 64 2d 73 65 74 2d |st index| ad-set-|
|00005650| 61 72 67 75 6d 65 6e 74 | 20 61 64 2d 65 6c 65 6d |argument| ad-elem|
|00005660| 65 6e 74 2d 61 63 63 65 | 73 73 20 61 64 2d 76 41 |ent-acce|ss ad-vA|
|00005670| 6c 55 65 53 20 73 65 74 | 71 20 61 64 2d 6c 69 73 |lUeS set|q ad-lis|
|00005680| 74 2d 61 63 63 65 73 73 | 20 73 65 74 63 64 72 20 |t-access| setcdr |
|00005690| 65 72 72 6f 72 20 22 61 | 64 2d 73 65 74 2d 61 72 |error "a|d-set-ar|
|000056a0| 67 75 6d 65 6e 74 73 3a | 20 4e 6f 20 61 72 67 75 |guments:| No argu|
|000056b0| 6d 65 6e 74 20 61 74 20 | 70 6f 73 69 74 69 6f 6e |ment at |position|
|000056c0| 20 25 64 20 6f 66 20 60 | 25 73 27 22 20 31 20 61 | %d of `|%s'" 1 a|
|000056d0| 64 2d 73 75 62 73 74 69 | 74 75 74 65 2d 74 72 65 |d-substi|tute-tre|
|000056e0| 65 20 23 5b 28 66 6f 72 | 6d 29 20 22 08 c1 61 87 |e #[(for|m) "..a.|
|000056f0| 22 20 5b 66 6f 72 6d 20 | 61 64 2d 76 41 6c 55 65 |" [form |ad-vAlUe|
|00005700| 53 5d 20 32 5d 20 23 5b | 28 66 6f 72 6d 29 20 22 |S] 2] #[|(form) "|
|00005710| 08 87 22 20 5b 76 61 6c | 75 65 73 2d 66 6f 72 6d |.." [val|ues-form|
|00005720| 5d 20 31 5d 20 6c 65 74 | 20 76 61 6c 75 65 73 2d |] 1] let| values-|
|00005730| 66 6f 72 6d 20 61 70 70 | 65 6e 64 20 72 65 76 65 |form app|end reve|
|00005740| 72 73 65 20 28 61 64 2d | 76 41 6c 55 65 53 29 5d |rse (ad-|vAlUeS)]|
|00005750| 20 36 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 6]).(de|falias '|
|00005760| 61 64 2d 69 6e 73 65 72 | 74 2d 61 72 67 75 6d 65 |ad-inser|t-argume|
|00005770| 6e 74 2d 61 63 63 65 73 | 73 2d 66 6f 72 6d 73 20 |nt-acces|s-forms |
|00005780| 23 5b 28 64 65 66 69 6e | 69 74 69 6f 6e 20 61 72 |#[(defin|ition ar|
|00005790| 67 6c 69 73 74 29 20 22 | c0 c1 c2 0b 23 87 22 20 |glist) "|....#." |
|000057a0| 5b 61 64 2d 73 75 62 73 | 74 69 74 75 74 65 2d 74 |[ad-subs|titute-t|
|000057b0| 72 65 65 20 23 5b 28 66 | 6f 72 6d 29 20 22 08 c1 |ree #[(f|orm) "..|
|000057c0| 61 ae 8a 08 a2 c2 73 ad | 84 08 41 a2 a8 87 22 20 |a.....s.|..A..." |
|000057d0| 5b 66 6f 72 6d 20 61 64 | 2d 61 72 67 2d 62 69 6e |[form ad|-arg-bin|
|000057e0| 64 69 6e 67 73 20 28 61 | 64 2d 67 65 74 2d 61 72 |dings (a|d-get-ar|
|000057f0| 67 20 61 64 2d 67 65 74 | 2d 61 72 67 73 20 61 64 |g ad-get|-args ad|
|00005800| 2d 73 65 74 2d 61 72 67 | 20 61 64 2d 73 65 74 2d |-set-arg| ad-set-|
|00005810| 61 72 67 73 29 5d 20 32 | 5d 20 23 5b 28 66 6f 72 |args)] 2|] #[(for|
|00005820| 6d 29 20 22 08 c1 61 ab | 84 c2 0b 21 87 08 40 08 |m) "..a.|...!..@.|
|00005830| 41 40 c4 08 41 0b 5c 22 | 41 40 1d 1e 06 89 1e 07 |A@..A.\"|A@......|
|00005840| c8 61 ab 87 c9 0b 0e 06 | 5c 22 aa a7 0e 07 ca 61 |.a......|\".....a|
|00005850| ab 88 cb 0b 0e 06 0d 23 | aa 99 0e 07 cc 61 ab 87 |.......#|.....a..|
|00005860| cd 0b 0e 06 5c 22 aa 8c | 0e 07 ce 61 ad 86 cf 0b |....\"..|...a....|
|00005870| 0e 06 0d 23 2b 87 22 20 | 5b 66 6f 72 6d 20 61 64 |...#+." |[form ad|
|00005880| 2d 61 72 67 2d 62 69 6e | 64 69 6e 67 73 20 61 64 |-arg-bin|dings ad|
|00005890| 2d 72 65 74 72 69 65 76 | 65 2d 61 72 67 73 2d 66 |-retriev|e-args-f|
|000058a0| 6f 72 6d 20 61 72 67 6c | 69 73 74 20 61 64 2d 69 |orm argl|ist ad-i|
|000058b0| 6e 73 65 72 74 2d 61 72 | 67 75 6d 65 6e 74 2d 61 |nsert-ar|gument-a|
|000058c0| 63 63 65 73 73 2d 66 6f | 72 6d 73 20 76 61 6c 20 |ccess-fo|rms val |
|000058d0| 69 6e 64 65 78 20 61 63 | 63 65 73 73 6f 72 20 61 |index ac|cessor a|
|000058e0| 64 2d 67 65 74 2d 61 72 | 67 20 61 64 2d 67 65 74 |d-get-ar|g ad-get|
|000058f0| 2d 61 72 67 75 6d 65 6e | 74 20 61 64 2d 73 65 74 |-argumen|t ad-set|
|00005900| 2d 61 72 67 20 61 64 2d | 73 65 74 2d 61 72 67 75 |-arg ad-|set-argu|
|00005910| 6d 65 6e 74 20 61 64 2d | 67 65 74 2d 61 72 67 73 |ment ad-|get-args|
|00005920| 20 61 64 2d 67 65 74 2d | 61 72 67 75 6d 65 6e 74 | ad-get-|argument|
|00005930| 73 20 61 64 2d 73 65 74 | 2d 61 72 67 73 20 61 64 |s ad-set|-args ad|
|00005940| 2d 73 65 74 2d 61 72 67 | 75 6d 65 6e 74 73 5d 20 |-set-arg|uments] |
|00005950| 36 5d 20 64 65 66 69 6e | 69 74 69 6f 6e 5d 20 34 |6] defin|ition] 4|
|00005960| 5d 29 0a 23 40 35 39 34 | 20 4d 61 6b 65 73 20 60 |]).#@594| Makes `|
|00005970| 66 75 6e 63 61 6c 6c 2f | 61 70 70 6c 79 27 20 66 |funcall/|apply' f|
|00005980| 6f 72 6d 20 74 6f 20 6d | 61 70 20 53 4f 55 52 43 |orm to m|ap SOURC|
|00005990| 45 2d 41 52 47 4c 49 53 | 54 20 74 6f 20 54 41 52 |E-ARGLIS|T to TAR|
|000059a0| 47 45 54 2d 41 52 47 4c | 49 53 54 2e 0a 54 68 65 |GET-ARGL|IST..The|
|000059b0| 20 61 72 67 75 6d 65 6e | 74 73 20 73 75 70 70 6c | argumen|ts suppl|
|000059c0| 69 65 64 20 74 6f 20 54 | 41 52 47 45 54 2d 41 52 |ied to T|ARGET-AR|
|000059d0| 47 4c 49 53 54 20 77 69 | 6c 6c 20 62 65 20 74 61 |GLIST wi|ll be ta|
|000059e0| 6b 65 6e 20 66 72 6f 6d | 20 53 4f 55 52 43 45 2d |ken from| SOURCE-|
|000059f0| 41 52 47 4c 49 53 54 20 | 6a 75 73 74 0a 61 73 20 |ARGLIST |just.as |
|00005a00| 69 66 20 74 68 65 79 20 | 68 61 64 20 62 65 65 6e |if they |had been|
|00005a10| 20 73 75 70 70 6c 69 65 | 64 20 74 6f 20 61 20 66 | supplie|d to a f|
|00005a20| 75 6e 63 74 69 6f 6e 20 | 77 69 74 68 20 54 41 52 |unction |with TAR|
|00005a30| 47 45 54 2d 41 52 47 4c | 49 53 54 20 64 69 72 65 |GET-ARGL|IST dire|
|00005a40| 63 74 6c 79 2e 20 0a 45 | 78 63 65 73 73 20 73 6f |ctly. .E|xcess so|
|00005a50| 75 72 63 65 20 61 72 67 | 75 6d 65 6e 74 73 20 77 |urce arg|uments w|
|00005a60| 69 6c 6c 20 62 65 20 6e | 65 67 6c 65 63 74 65 64 |ill be n|eglected|
|00005a70| 2c 20 6d 69 73 73 69 6e | 67 20 73 6f 75 72 63 65 |, missin|g source|
|00005a80| 20 61 72 67 75 6d 65 6e | 74 73 20 77 69 6c 6c 20 | argumen|ts will |
|00005a90| 62 65 20 0a 73 75 70 70 | 6c 69 65 64 20 61 73 20 |be .supp|lied as |
|00005aa0| 6e 69 6c 2e 20 20 52 65 | 74 75 72 6e 73 20 61 20 |nil. Re|turns a |
|00005ab0| 60 66 75 6e 63 61 6c 6c | 27 20 6f 72 20 60 61 70 |`funcall|' or `ap|
|00005ac0| 70 6c 79 27 20 66 6f 72 | 6d 20 77 69 74 68 20 74 |ply' for|m with t|
|00005ad0| 68 65 20 73 65 63 6f 6e | 64 20 65 6c 65 6d 65 6e |he secon|d elemen|
|00005ae0| 74 0a 62 65 69 6e 67 20 | 60 66 75 6e 63 74 69 6f |t.being |`functio|
|00005af0| 6e 27 20 77 68 69 63 68 | 20 68 61 73 20 74 6f 20 |n' which| has to |
|00005b00| 62 65 20 72 65 70 6c 61 | 63 65 64 20 62 79 20 61 |be repla|ced by a|
|00005b10| 6e 20 61 63 74 75 61 6c | 20 66 75 6e 63 74 69 6f |n actual| functio|
|00005b20| 6e 20 61 72 67 75 6d 65 | 6e 74 2e 0a 45 78 61 6d |n argume|nt..Exam|
|00005b30| 70 6c 65 3a 20 60 28 61 | 64 2d 6d 61 70 2d 61 72 |ple: `(a|d-map-ar|
|00005b40| 67 6c 69 73 74 73 20 27 | 28 61 20 26 72 65 73 74 |glists '|(a &rest|
|00005b50| 20 61 72 67 73 29 20 27 | 28 77 20 78 20 79 20 7a | args) '|(w x y z|
|00005b60| 29 29 27 20 77 69 6c 6c | 20 72 65 74 75 72 6e 0a |))' will| return.|
|00005b70| 20 20 20 20 20 20 20 20 | 20 60 28 66 75 6e 63 61 | | `(funca|
|00005b80| 6c 6c 20 66 75 6e 63 74 | 69 6f 6e 20 61 20 28 63 |ll funct|ion a (c|
|00005b90| 61 72 20 61 72 67 73 29 | 20 28 63 61 72 20 28 63 |ar args)| (car (c|
|00005ba0| 64 72 20 61 72 67 73 29 | 29 20 28 6e 74 68 20 32 |dr args)|) (nth 2|
|00005bb0| 20 61 72 67 73 29 29 27 | 2e 1f 0a 28 64 65 66 61 | args))'|...(defa|
|00005bc0| 6c 69 61 73 20 27 61 64 | 2d 6d 61 70 2d 61 72 67 |lias 'ad|-map-arg|
|00005bd0| 6c 69 73 74 73 20 23 5b | 28 73 6f 75 72 63 65 2d |lists #[|(source-|
|00005be0| 61 72 67 6c 69 73 74 20 | 74 61 72 67 65 74 2d 61 |arglist |target-a|
|00005bf0| 72 67 6c 69 73 74 29 20 | 22 c0 09 21 1a c3 5c 6e |rglist) |"..!..\n|
|00005c00| 40 5c 6e 41 40 5c 22 1c | c5 5c 6e 38 1e 06 c0 0e |@\nA@\".|.\n8....|
|00005c10| 07 21 1e 08 c3 0e 08 40 | 0e 08 41 40 5c 22 1e 09 |.!.....@|..A@\"..|
|00005c20| c5 0e 08 38 1e 5c 6e 0e | 06 ad 82 0e 5c 6e 1e 0b |...8.\n.|....\n..|
|00005c30| cc 1e 0d c3 0e 0b ab 83 | ce aa 81 cf d0 44 0e 0b |........|.....D..|
|00005c40| ab 88 c3 0c 0e 06 43 5c | 22 aa 90 d1 d2 c3 0e 09 |......C\|".......|
|00005c50| 0e 5c 6e ad 85 0e 09 47 | 0c 9b 5c 22 5c 22 5c 22 |.\n....G|..\"\"\"|
|00005c60| 2e 08 87 22 20 5b 61 64 | 2d 70 61 72 73 65 2d 61 |..." [ad|-parse-a|
|00005c70| 72 67 6c 69 73 74 20 73 | 6f 75 72 63 65 2d 61 72 |rglist s|ource-ar|
|00005c80| 67 6c 69 73 74 20 70 61 | 72 73 65 64 2d 73 6f 75 |glist pa|rsed-sou|
|00005c90| 72 63 65 2d 61 72 67 6c | 69 73 74 20 61 70 70 65 |rce-argl|ist appe|
|00005ca0| 6e 64 20 73 6f 75 72 63 | 65 2d 72 65 71 6f 70 74 |nd sourc|e-reqopt|
|00005cb0| 2d 61 72 67 73 20 32 20 | 73 6f 75 72 63 65 2d 72 |-args 2 |source-r|
|00005cc0| 65 73 74 2d 61 72 67 20 | 74 61 72 67 65 74 2d 61 |est-arg |target-a|
|00005cd0| 72 67 6c 69 73 74 20 70 | 61 72 73 65 64 2d 74 61 |rglist p|arsed-ta|
|00005ce0| 72 67 65 74 2d 61 72 67 | 6c 69 73 74 20 74 61 72 |rget-arg|list tar|
|00005cf0| 67 65 74 2d 72 65 71 6f | 70 74 2d 61 72 67 73 20 |get-reqo|pt-args |
|00005d00| 74 61 72 67 65 74 2d 72 | 65 73 74 2d 61 72 67 20 |target-r|est-arg |
|00005d10| 6e 65 65 64 2d 61 70 70 | 6c 79 20 2d 31 20 74 61 |need-app|ly -1 ta|
|00005d20| 72 67 65 74 2d 61 72 67 | 2d 69 6e 64 65 78 20 61 |rget-arg|-index a|
|00005d30| 70 70 6c 79 20 66 75 6e | 63 61 6c 6c 20 66 75 6e |pply fun|call fun|
|00005d40| 63 74 69 6f 6e 20 6d 61 | 70 63 61 72 20 23 5b 28 |ction ma|pcar #[(|
|00005d50| 61 72 67 29 20 22 08 54 | 10 c1 5c 6e 08 5c 22 87 |arg) ".T|..\n.\".|
|00005d60| 22 20 5b 74 61 72 67 65 | 74 2d 61 72 67 2d 69 6e |" [targe|t-arg-in|
|00005d70| 64 65 78 20 61 64 2d 67 | 65 74 2d 61 72 67 75 6d |dex ad-g|et-argum|
|00005d80| 65 6e 74 20 73 6f 75 72 | 63 65 2d 61 72 67 6c 69 |ent sour|ce-argli|
|00005d90| 73 74 5d 20 33 5d 5d 20 | 38 20 28 23 24 20 2e 20 |st] 3]] |8 (#$ . |
|00005da0| 32 32 38 38 39 29 5d 29 | 0a 28 64 65 66 61 6c 69 |22889)])|.(defali|
|00005db0| 61 73 20 27 61 64 2d 6d | 61 6b 65 2d 6d 61 70 70 |as 'ad-m|ake-mapp|
|00005dc0| 65 64 2d 63 61 6c 6c 20 | 23 5b 28 73 6f 75 72 63 |ed-call |#[(sourc|
|00005dd0| 65 2d 61 72 67 6c 69 73 | 74 20 74 61 72 67 65 74 |e-arglis|t target|
|00005de0| 2d 61 72 67 6c 69 73 74 | 20 74 61 72 67 65 74 2d |-arglist| target-|
|00005df0| 66 75 6e 63 74 69 6f 6e | 29 20 22 c0 09 5c 6e 5c |function|) "..\n\|
|00005e00| 22 89 1b 40 c4 61 ab 87 | 0d 0b 41 41 42 aa 88 0b |"..@.a..|..AAB...|
|00005e10| 89 41 c6 0d 44 a0 88 29 | 87 22 20 5b 61 64 2d 6d |.A..D..)|." [ad-m|
|00005e20| 61 70 2d 61 72 67 6c 69 | 73 74 73 20 73 6f 75 72 |ap-argli|sts sour|
|00005e30| 63 65 2d 61 72 67 6c 69 | 73 74 20 74 61 72 67 65 |ce-argli|st targe|
|00005e40| 74 2d 61 72 67 6c 69 73 | 74 20 6d 61 70 70 65 64 |t-arglis|t mapped|
|00005e50| 2d 66 6f 72 6d 20 66 75 | 6e 63 61 6c 6c 20 74 61 |-form fu|ncall ta|
|00005e60| 72 67 65 74 2d 66 75 6e | 63 74 69 6f 6e 20 71 75 |rget-fun|ction qu|
|00005e70| 6f 74 65 5d 20 35 5d 29 | 0a 28 64 65 66 61 6c 69 |ote] 5])|.(defali|
|00005e80| 61 73 20 27 61 64 2d 6d | 61 6b 65 2d 73 69 6e 67 |as 'ad-m|ake-sing|
|00005e90| 6c 65 2d 61 64 76 69 63 | 65 2d 64 6f 63 73 74 72 |le-advic|e-docstr|
|00005ea0| 69 6e 67 20 23 5b 28 61 | 64 76 69 63 65 20 63 6c |ing #[(a|dvice cl|
|00005eb0| 61 73 73 20 26 6f 70 74 | 69 6f 6e 61 6c 20 73 74 |ass &opt|ional st|
|00005ec0| 79 6c 65 29 20 22 c0 c1 | 5c 6e 38 21 1b 0c c5 61 |yle) "..|\n8!...a|
|00005ed0| ab 83 0b aa af 0c c6 61 | ab 94 c7 c8 0e 09 5c 6e |.......a|......\n|
|00005ee0| 40 0b ab 83 ca aa 81 cb | 0b ae 81 cb 25 aa 96 c7 |@.......|....%...|
|00005ef0| cc cd ce 0e 09 21 21 5c | 6e 40 0b ab 83 ca aa 81 |.....!!\|n@......|
|00005f00| cb 0b ae 81 cb 25 29 87 | 22 20 5b 61 64 2d 64 6f |.....%).|" [ad-do|
|00005f10| 63 73 74 72 69 6e 67 20 | 33 20 61 64 76 69 63 65 |cstring |3 advice|
|00005f20| 20 61 64 76 69 63 65 2d | 64 6f 63 73 74 72 69 6e | advice-|docstrin|
|00005f30| 67 20 73 74 79 6c 65 20 | 70 6c 61 69 6e 20 66 72 |g style |plain fr|
|00005f40| 65 65 7a 65 20 66 6f 72 | 6d 61 74 20 22 50 65 72 |eeze for|mat "Per|
|00005f50| 6d 61 6e 65 6e 74 20 25 | 73 2d 61 64 76 69 63 65 |manent %|s-advice|
|00005f60| 20 60 25 73 27 3a 25 73 | 25 73 22 20 63 6c 61 73 | `%s':%s|%s" clas|
|00005f70| 73 20 22 5c 6e 22 20 22 | 22 20 22 25 73 2d 61 64 |s "\n" "|" "%s-ad|
|00005f80| 76 69 63 65 20 60 25 73 | 27 3a 25 73 25 73 22 20 |vice `%s|':%s%s" |
|00005f90| 63 61 70 69 74 61 6c 69 | 7a 65 20 73 79 6d 62 6f |capitali|ze symbo|
|00005fa0| 6c 2d 6e 61 6d 65 5d 20 | 36 5d 29 0a 28 64 65 66 |l-name] |6]).(def|
|00005fb0| 61 6c 69 61 73 20 27 61 | 64 2d 6d 61 6b 65 2d 61 |alias 'a|d-make-a|
|00005fc0| 64 76 69 73 65 64 2d 64 | 6f 63 73 74 72 69 6e 67 |dvised-d|ocstring|
|00005fd0| 20 23 5b 28 66 75 6e 63 | 74 69 6f 6e 20 26 6f 70 | #[(func|tion &op|
|00005fe0| 74 69 6f 6e 61 6c 20 73 | 74 79 6c 65 29 20 22 c0 |tional s|tyle) ".|
|00005ff0| 09 21 1a c3 c4 5c 6e 21 | 21 1d c6 5c 6e c7 5c 22 |.!...\n!|!..\n.\"|
|00006000| 1e 08 c9 1e 5c 6e c9 1e | 0b 0e 08 ab 85 0e 08 43 |....\n..|.......C|
|00006010| 16 5c 6e 0e 0c cd 61 ac | 89 ce 0d cf 51 0e 5c 6e |.\n...a.|....Q.\n|
|00006020| 42 16 5c 6e 0e 10 c9 1e | 11 89 1e 12 ab bc 0e 12 |B.\n....|........|
|00006030| 40 16 11 d3 09 0e 11 5c | 22 c9 1e 14 89 1e 12 ab |@......\|".......|
|00006040| a1 0e 12 40 16 14 d5 0e | 14 0e 11 0e 0c 23 89 16 |...@....|.....#..|
|00006050| 0b ab 87 0e 0b 0e 5c 6e | 42 16 5c 6e 0e 12 41 89 |......\n|B.\n..A.|
|00006060| 16 12 ac 5f 2a 0e 12 41 | 89 16 12 ac 44 2a 0e 5c |..._*..A|....D*.\|
|00006070| 6e ad 87 d6 d7 0e 5c 6e | 9f d8 23 2d 87 22 20 5b |n.....\n|..#-." [|
|00006080| 61 64 2d 72 65 61 6c 2d | 6f 72 69 67 2d 64 65 66 |ad-real-|orig-def|
|00006090| 69 6e 69 74 69 6f 6e 20 | 66 75 6e 63 74 69 6f 6e |inition |function|
|000060a0| 20 6f 72 69 67 64 65 66 | 20 73 79 6d 62 6f 6c 2d | origdef| symbol-|
|000060b0| 6e 61 6d 65 20 61 64 2d | 64 65 66 69 6e 69 74 69 |name ad-|definiti|
|000060c0| 6f 6e 2d 74 79 70 65 20 | 6f 72 69 67 74 79 70 65 |on-type |origtype|
|000060d0| 20 61 64 2d 72 65 61 6c | 2d 64 6f 63 75 6d 65 6e | ad-real|-documen|
|000060e0| 74 61 74 69 6f 6e 20 74 | 20 6f 72 69 67 64 6f 63 |tation t| origdoc|
|000060f0| 20 6e 69 6c 20 70 61 72 | 61 67 72 61 70 68 73 20 | nil par|agraphs |
|00006100| 61 64 76 69 63 65 2d 64 | 6f 63 73 74 72 69 6e 67 |advice-d|ocstring|
|00006110| 20 73 74 79 6c 65 20 70 | 6c 61 69 6e 20 22 54 68 | style p|lain "Th|
|00006120| 69 73 20 22 20 22 20 69 | 73 20 61 64 76 69 73 65 |is " " i|s advise|
|00006130| 64 2e 22 20 61 64 2d 61 | 64 76 69 63 65 2d 63 6c |d." ad-a|dvice-cl|
|00006140| 61 73 73 65 73 20 63 6c | 61 73 73 20 61 64 2d 64 |asses cl|ass ad-d|
|00006150| 4f 2d 76 41 72 20 61 64 | 2d 67 65 74 2d 65 6e 61 |O-vAr ad|-get-ena|
|00006160| 62 6c 65 64 2d 61 64 76 | 69 63 65 73 20 61 64 76 |bled-adv|ices adv|
|00006170| 69 63 65 20 61 64 2d 6d | 61 6b 65 2d 73 69 6e 67 |ice ad-m|ake-sing|
|00006180| 6c 65 2d 61 64 76 69 63 | 65 2d 64 6f 63 73 74 72 |le-advic|e-docstr|
|00006190| 69 6e 67 20 6d 61 70 63 | 6f 6e 63 61 74 20 69 64 |ing mapc|oncat id|
|000061a0| 65 6e 74 69 74 79 20 22 | 5c 6e 5c 6e 22 5d 20 35 |entity "|\n\n"] 5|
|000061b0| 5d 29 0a 28 64 65 66 61 | 6c 69 61 73 20 27 61 64 |]).(defa|lias 'ad|
|000061c0| 2d 6d 61 6b 65 2d 70 6c | 61 69 6e 2d 64 6f 63 73 |-make-pl|ain-docs|
|000061d0| 74 72 69 6e 67 20 23 5b | 28 66 75 6e 63 74 69 6f |tring #[|(functio|
|000061e0| 6e 29 20 22 c0 09 c2 5c | 22 87 22 20 5b 61 64 2d |n) "...\|"." [ad-|
|000061f0| 6d 61 6b 65 2d 61 64 76 | 69 73 65 64 2d 64 6f 63 |make-adv|ised-doc|
|00006200| 73 74 72 69 6e 67 20 66 | 75 6e 63 74 69 6f 6e 20 |string f|unction |
|00006210| 70 6c 61 69 6e 5d 20 33 | 5d 29 0a 28 64 65 66 61 |plain] 3|]).(defa|
|00006220| 6c 69 61 73 20 27 61 64 | 2d 6d 61 6b 65 2d 66 72 |lias 'ad|-make-fr|
|00006230| 65 65 7a 65 2d 64 6f 63 | 73 74 72 69 6e 67 20 23 |eeze-doc|string #|
|00006240| 5b 28 66 75 6e 63 74 69 | 6f 6e 29 20 22 c0 09 c2 |[(functi|on) "...|
|00006250| 5c 22 87 22 20 5b 61 64 | 2d 6d 61 6b 65 2d 61 64 |\"." [ad|-make-ad|
|00006260| 76 69 73 65 64 2d 64 6f | 63 73 74 72 69 6e 67 20 |vised-do|cstring |
|00006270| 66 75 6e 63 74 69 6f 6e | 20 66 72 65 65 7a 65 5d |function| freeze]|
|00006280| 20 33 5d 29 0a 28 64 65 | 66 61 6c 69 61 73 20 27 | 3]).(de|falias '|
|00006290| 61 64 2d 61 64 76 69 73 | 65 64 2d 61 72 67 6c 69 |ad-advis|ed-argli|
|000062a0| 73 74 20 23 5b 28 66 75 | 6e 63 74 69 6f 6e 29 20 |st #[(fu|nction) |
|000062b0| 22 c0 c1 8d 87 22 20 5b | 61 64 2d 64 4f 2d 65 58 |"...." [|ad-dO-eX|
|000062c0| 69 54 20 28 62 79 74 65 | 2d 63 6f 64 65 20 22 c0 |iT (byte|-code ".|
|000062d0| c1 5c 6e c3 5c 22 c1 5c | 6e c4 5c 22 c1 5c 6e c5 |.\n.\".\|n.\".\n.|
|000062e0| 5c 22 23 c6 1e 07 89 1e | 08 ab 9f 0e 08 40 16 07 |\"#.....|.....@..|
|000062f0| c9 ca 0e 07 38 21 89 1e | 0b ab 86 cc cd 0e 0b 5c |....8!..|.......\|
|00006300| 22 88 29 0e 08 41 89 16 | 08 ac 61 2a c6 87 22 20 |".)..A..|..a*.." |
|00006310| 5b 61 70 70 65 6e 64 20 | 61 64 2d 67 65 74 2d 65 |[append |ad-get-e|
|00006320| 6e 61 62 6c 65 64 2d 61 | 64 76 69 63 65 73 20 66 |nabled-a|dvices f|
|00006330| 75 6e 63 74 69 6f 6e 20 | 62 65 66 6f 72 65 20 61 |unction |before a|
|00006340| 72 6f 75 6e 64 20 61 66 | 74 65 72 20 6e 69 6c 20 |round af|ter nil |
|00006350| 61 64 76 69 63 65 20 61 | 64 2d 64 4f 2d 76 41 72 |advice a|d-dO-vAr|
|00006360| 20 61 64 2d 61 72 67 6c | 69 73 74 20 33 20 61 72 | ad-argl|ist 3 ar|
|00006370| 67 6c 69 73 74 20 74 68 | 72 6f 77 20 61 64 2d 64 |glist th|row ad-d|
|00006380| 4f 2d 65 58 69 54 5d 20 | 37 29 5d 20 32 5d 29 0a |O-eXiT] |7)] 2]).|
|00006390| 28 64 65 66 61 6c 69 61 | 73 20 27 61 64 2d 61 64 |(defalia|s 'ad-ad|
|000063a0| 76 69 73 65 64 2d 69 6e | 74 65 72 61 63 74 69 76 |vised-in|teractiv|
|000063b0| 65 2d 66 6f 72 6d 20 23 | 5b 28 66 75 6e 63 74 69 |e-form #|[(functi|
|000063c0| 6f 6e 29 20 22 c0 c1 8d | 87 22 20 5b 61 64 2d 64 |on) "...|." [ad-d|
|000063d0| 4f 2d 65 58 69 54 20 28 | 62 79 74 65 2d 63 6f 64 |O-eXiT (|byte-cod|
|000063e0| 65 20 22 c0 c1 5c 6e c3 | 5c 22 c1 5c 6e c4 5c 22 |e "..\n.|\".\n.\"|
|000063f0| c1 5c 6e c5 5c 22 23 c6 | 1e 07 89 1e 08 ab 9f 0e |.\n.\"#.|........|
+--------+-------------------------+-------------------------+--------+--------+
Only 25.0 KB of data is shown above.